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

时间:2008-09-26 13:23:02

标签: php string var-dump

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

PHP文档说;

  

与将结果直接输出到浏览器的任何内容一样,output-control functions可用于捕获此函数的输出,并将其保存在字符串中(例如)。

有人能给我一个如何运作的例子吗?

print_r()不是一个有效的可能性,因为它不会向我提供我需要的信息。

13 个答案:

答案 0 :(得分:810)

尝试var_export

您可能想要查看var_export - 虽然它不提供与var_dump相同的输出,但它确实提供了第二个$return参数,这将导致它返回其输出而非打印它:

$debug = var_export($my_var, true);

为什么?

我更喜欢这种单行使用ob_startob_get_clean()。我还发现输出更容易阅读,因为它只是PHP代码。

var_dumpvar_export之间的区别在于var_export返回变量“的”可解析字符串表示,而var_dump只是转储信息关于变量。这在实践中意味着var_export为您提供了有效的PHP代码(但可能无法提供有关该变量的更多信息,特别是如果您正在使用resources)。

演示:

$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*

答案 1 :(得分:556)

使用输出缓冲:

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

答案 2 :(得分:68)

你也可以这样做:

$dump = print_r($variable, true);

答案 3 :(得分:15)

您也可以尝试使用serialize()函数,有时它对调试非常有用。

答案 4 :(得分:13)

function return_var_dump(){
    //works like var_dump, but 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();
}

答案 5 :(得分:12)

同样echo json_encode($dataobject);可能会有所帮助

答案 6 :(得分:7)

我知道这个问题已经过时了,但是没有人提到这一点。

来自PHP manual

  

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

所以,这是PHP&#39; 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 '';
}

干杯。

答案 7 :(得分:5)

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

答案 8 :(得分:4)

这是功能完整的解决方案。

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

答案 9 :(得分:2)

这可能有点偏离主题。

我一直在寻找一种方法将这种信息写入我的PHP-FPM容器的Docker日志中,并提供了下面的代码片段。我确信这可以被Docker PHP-FPM用户使用。

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

答案 10 :(得分:0)

我非常喜欢var_dump()的详细输出,对var_export()print_r()的输出不满意,因为它没有提供太多信息(例如,数据类型)丢失,长度丢失)。

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

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

请注意,如果您使用彩色的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)

希望它可以帮助某人。

答案 11 :(得分:-1)

长字符串:只需使用echo($var);而不是dump($var);

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

答案 12 :(得分:-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
}