如何将var_dump的结果捕获到字符串?


605

我想捕获var_dump到字符串的输出。

PHP文档说:

与将结果直接输出到浏览器的任何东西一样,输出控制功能可用于捕获此功能的输出,并将其保存在字符串中(例如)。

这可能如何工作的一个例子是什么?

print_r() 这是不可能的,因为它不会给我所需的信息。

Answers:


601

使用输出缓冲:

<?php
ob_start();
var_dump($someVar);
$result = ob_get_clean();
?>

8
使用输出缓冲很可能会对此处的性能产生负面影响。如果您需要在执行复杂脚本的过程中查看多个变量,它也会变得非常混乱。
selfawaresoup

83
@Inwdr我只使用过var_dump作为调试的便利功能,并且肯定从未将var_dump语句留在生产代码中。我想这是典型的。在这种情况下,性能不太可能完全相关。
Mark Amery

还使用删除标签以提高可读性(如果只需要字符串)strip_tags(),这将仅返回类型和值。
阿尼尔(Anil)2013年

11
这是对问题的一个很好的字面答案,因为您正像询问的那样“将var_dump的结果捕获到字符串中”。从本质上讲,var_export()是一个更好的答案,因为它通常更有意义。
来自Qaribou,2014年

1
@AlbertHendriks我更喜欢var_dump。启用Xdebug后,将显示漂亮的数据。
罗布(Robsch)

880

尝试 var_export

您可能想签出var_export—尽管它没有提供与var_dump提供第二个$return参数相同的输出,但它会导致第二个参数返回而不是打印输出:

$debug = var_export($my_var, true);

为什么?

与使用ob_start和相比,我更喜欢这种单行代码ob_get_clean()。我还发现该输出更易于阅读,因为它只是PHP代码。

var_dump和之间的区别var_export是,它var_export返回“变量的可解析字符串表示形式”,var_dump只是转储有关变量的信息。实际上,这意味着var_export给您有效的PHP代码(但可能不会为您提供有关变量的足够多的信息,尤其是在使用资源的情况下)。

演示:

$demo = array(
    "bool" => false,
    "int" => 1,
    "float" => 3.14,
    "string" => "hello world",
    "array" => array(),
    "object" => new stdClass(),
    "resource" => tmpfile(),
    "null" => null,
);

// var_export -- nice, one-liner
$debug_export = var_export($demo, true);

// var_dump
ob_start();
var_dump($demo);
$debug_dump = ob_get_clean();

// print_r -- included for completeness, though not recommended
$debug_printr = print_r($demo, true);

输出的差异:

var_export($debug_export在上面的示例中):

 array (
  'bool' => false,
  'int' => 1,
  'float' => 3.1400000000000001,
  'string' => 'hello world',
  'array' => 
  array (
  ),
  'object' => 
  stdClass::__set_state(array(
  )),
  'resource' => NULL, // Note that this resource pointer is now NULL
  'null' => NULL,
)

var_dump($debug_dump在上面的示例中):

 array(8) {
  ["bool"]=>
  bool(false)
  ["int"]=>
  int(1)
  ["float"]=>
  float(3.14)
  ["string"]=>
  string(11) "hello world"
  ["array"]=>
  array(0) {
  }
  ["object"]=>
  object(stdClass)#1 (0) {
  }
  ["resource"]=>
  resource(4) of type (stream)
  ["null"]=>
  NULL
}

print_r($debug_printr在上面的示例中):

Array
(
    [bool] => 
    [int] => 1
    [float] => 3.14
    [string] => hello world
    [array] => Array
        (
        )

    [object] => stdClass Object
        (
        )

    [resource] => Resource id #4
    [null] => 
)

警告:var_export不处理循环引用

如果您尝试使用循环引用转储变量,则调用var_export将导致PHP警告:

 $circular = array();
 $circular['self'] =& $circular;
 var_export($circular);

结果是:

 Warning: var_export does not handle circular references in example.php on line 3
 array (
   'self' => 
   array (
     'self' => NULL,
   ),
 )

两个var_dumpprint_r,另一方面,将输出串*RECURSION*遇到循环引用时。


11
绝对比接受的答案更好。我很惊讶它没有更多投票!您能否详细说明为什么它无法提供他正在寻找的所有信息?
JMTyler

7
@JMTyler var_export返回一个可分析的字符串(本质上是PHP代码),而var_dump提供数据的原始转储。因此,例如,如果您对值为1的整数调用var_dump,则它将打印,int(1)而var_export仅打印出1
inxilpro

4
如果在var_dump工作时将其与$ GLOBALS一起使用,则var_export将落在其腹部。
奥拉夫2013年

3
不适用于包含对其自身引用的变量。var_export不能像var_dump一样工作;像这样,$ v = []; $ v [] =&$ v; var_export($ v,true); ...
hanshenrik

3
别再炒作了var_export实际上对于调试而言并没有更好的效果,因为您无法在浏览器中搜索(int)或(字符串)等。它还会将大量信息整理到一个很小的空间中,请尝试:var_export(''); var_export('\'');。最重要的是,为PHP致命错误做好准备嵌套级别太深-递归依赖项?在第75行的C:\ path \ file.php中
Pacerier,2015年

76

您也可以这样做:

$dump = print_r($variable, true);

17
我确实确实提到了var_dump :)
Mark Biek

7
我个人更喜欢print_r在可能的地方使用,但是不幸的是有时它不能提供足够的信息。举例来说,因为它强制转换成字符串,其中就可以了,既falsenull显示为空字符串。如果我在意这两者之间的差异,我会勉强诉诸于var_dumpvar_export
JMTyler 2013年


15
function return_var_dump(){
    // It works like var_dump, but it returns a string instead of printing it.
    $args = func_get_args(); // For <5.3.0 support ...
    ob_start();
    call_user_func_array('var_dump', $args);
    return ob_get_clean();
}

4
@MarkAmery似乎是真的。我让事情变得简单。
hanshenrik 2014年

13

echo json_encode($dataobject);可能有帮助


1
在这种情况下,我认为输出非常混乱,与调试目的相去甚远。
托马什Zato -恢复莫妮卡

2
马克·比耶克(Mark Biek)没有对调试说什么,是吗?也许他只需要将对象保存在数据库中即可。在这种情况下,我提供的方法会很好用。无论如何,感谢您的注意,TomášZato。
ZurabWeb

无论如何,json_encode将不会包含所有数据var_dump(例如,作为变量类型)。以不同的格式json_encode输出与相同的信息print_R
托马什Zato -恢复莫妮卡

1
好的,我会再解释一次。OT表示他需要输出var_dump。他还说,该print_R信息不足以满足他的需要。json_encode和提供的信息没有真正的区别print_r-只有数据格式不同。鉴于此,如果print_r不足,则为json_encode。请不要再抱怨低票了。显然,这不只是随机点击,所以要处理它。
托马什Zato -恢复莫妮卡

9

从PHP手册

此函数显示有关一个或多个表达式的结构化信息,包括其类型和值。

因此,这是PHP的真正返回版本var_dump(),它实际上接受可变长度的参数列表:

function var_dump_str()
{
    $argc = func_num_args();
    $argv = func_get_args();

    if ($argc > 0) {
        ob_start();
        call_user_func_array('var_dump', $argv);
        $result = ob_get_contents();
        ob_end_clean();
        return $result;
    }

    return '';
}

1
+1用于提供对实际问题的真实答案。我正在阅读这篇文章是因为我需要var_dump,而不是var_export,print_r,serialize,json_encode或真正的调试器。我也知道如何使用它们。OP要求var_dump,我需要var_dump。谢谢!
Slashback 2015年

如果您想对var_dump保持真实,则必须trigger_error(“ var_dump_str()的参数计数错误”); 当argc <= 0时; 还是更好,让var_dump为您完成。:p
hanshenrik 2015年

这几乎没有添加尚未接受的答案中的任何内容。$argc正如@hanshenrik指出的那样,此处的检查是不必要的,而且可以说是不正确的,一旦删除该检查,您真正添加的就是call_user_func_arrayand func_get_args调用。
Mark Amery

5

如果要在运行时查看变量的内容,请考虑使用真正的调试器,例如XDebug。这样,您无需弄乱源代码,即使普通用户访问您的应用程序,也可以使用调试器。他们不会注意到。


5

以下是作为功能的完整解决方案:

function varDumpToString ($var)
{
    ob_start();
    var_dump($var);
    return ob_get_clean();
}

2
不能使用超过1个变量... var_dump(“ foo”,“ bar”)=>字符串(3)“ foo”字符串(3)“ bar” varDumpToString(“ foo”,“ bar”)=> string(3)“ foo”
hanshenrik

2

这可能有点题外话。

我正在寻找一种将此类信息写入我的PHP-FPM容器的Docker日志的方法,并提出了以下代码段。我确信Docker PHP-FPM用户可以使用它。

fwrite(fopen('php://stdout', 'w'), var_export($object, true));

1
该句柄永远不会关闭,因此这是资源泄漏,这可能是长时间运行的守护程序样式脚本中的问题。但请尝试file_put_contents('php://stdout',var_export($object, true),FILE_APPEND);
hanshenrik '19

0

我真的很喜欢var_dump()'s的详细输出,并且对var_export()'s或print_r()'的输出不满意,因为它没有提供太多信息(例如,缺少数据类型,缺少长度)。

为了编写安全且可预测的代码,有时区分空字符串和null很有用。或介于1和true之间。或介于null和false之间。所以我想在输出中输入数据类型。

尽管有帮助,但是我没有在现有响应中找到一个干净,简单的解决方案来将彩色输出转换为var_dump()易于理解的输出,转换为没有html标签并包含的所有详细信息的字符串var_dump()

请注意,如果您使用的是color var_dump(),则意味着您已安装Xdebug,它将覆盖php的默认值var_dump()以添加html颜色。

出于这个原因,我创建了这个略有不同的变体,给出了我所需要的:

function dbg_var_dump($var)
    {
        ob_start();
        var_dump($var);
        $result = ob_get_clean();
        return strip_tags(strtr($result, ['=&gt;' => '=>']));
    }

返回下面的漂亮字符串:

array (size=6)
  'functioncall' => string 'add-time-property' (length=17)
  'listingid' => string '57' (length=2)
  'weekday' => string '0' (length=1)
  'starttime' => string '00:00' (length=5)
  'endtime' => string '00:00' (length=5)
  'price' => string '' (length=0)

希望它可以帮助某人。


-2

http://htmlexplorer.com/2015/01/assign-output-var_dump-print_r-php-variable.html

var_dump和print_r函数只能直接输出到浏览器。因此,只能使用php的输出控制功能来检索这些功能的输出。下面的方法可能对保存输出有用。

function assignVarDumpValueToString($object) {
    ob_start();
    var_dump($object);
    $result = ob_get_clean();
    return $result;
}

ob_get_clean()只能清除最后输入到内部缓冲区的数据。因此,如果您有多个条目,那么ob_get_contents方法将很有用。

来自与上述相同的来源:

function varDumpToErrorLog( $var=null ){
    ob_start();                    // start reading the internal buffer
    var_dump( $var);          
    $grabbed_information = ob_get_contents(); // assigning the internal buffer contents to variable
    ob_end_clean();                // clearing the internal buffer.
    error_log( $grabbed_information);        // saving the information to error_log
}

1
当您引用其他来源的材料时,请正确指出。在我要进行的编辑之前,此答案中唯一以引号格式设置的部分是您没有从某人的博客复制和粘贴的部分。
Mark Amery

-2

长字符串:仅用于echo($var);代替dump($var);

对象数组var_dump('<pre>'.json_encode($var).'</pre>);'

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.