我想输出捕捉var_dump
为字符串。
PHP的文件说;
与任何其结果直接输出到浏览器时, 输出控制功能可以用来捕获该函数的输出,并将其保存在一个字符串(例如)。
有人可以给我如何可能的工作的例子吗?
print_r()
不是因为它不会给我我需要的信息,有效的可能性。
我想输出捕捉var_dump
为字符串。
PHP的文件说;
与任何其结果直接输出到浏览器时, 输出控制功能可以用来捕获该函数的输出,并将其保存在一个字符串(例如)。
有人可以给我如何可能的工作的例子吗?
print_r()
不是因为它不会给我我需要的信息,有效的可能性。
使用输出缓冲:
<?php
ob_start();
var_dump($someVar);
$result = ob_get_clean();
?>
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);
$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,
)
$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
}
$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_dump
和print_r
,而另一方面,将输出字符串*RECURSION*
遇到时循环引用。
你也可以这样做:
$dump = print_r($variable, true);
你也可以尝试使用serialize()
函数,有时很为调试运行puprposes有用。
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();
}
也echo json_encode($dataobject);
可能是有益的
我知道,这个问题是旧的,但没有人提到这一点。
从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 '';
}
干杯。
如果你想运行时可以看一个变量的内容,可以考虑使用像XDebug的一个真正的调试。 这样,你不需要弄乱你的源代码,甚至而正常用户访问你的应用程序,你可以使用一个调试器。 他们不会注意到。
这里是功能完整的解决方案。
function varDumpToString ($var)
{
ob_start();
var_dump($var);
return ob_get_clean();
}
这也许有点题外话。
我一直在寻找一种方式来这类信息写信给我的PHP-FPM集装箱的码头工人数,并与下面的代码片段上来。 我敢肯定,这可以通过多克PHP-FPM用户使用。
fwrite(fopen('php://stdout', 'w'), var_export($object, true));
我真的很喜欢var_dump()
的详细输出并不满意var_export()
的或print_r()
的输出,因为它没有给尽可能多的信息(例如数据丢失键入,长度缺失)。
编写安全的和可预测的代码,有时它是有用的一个空字符串和一个空的区分。 或1和真正之间。 或空和假之间。 所以我想在我的输出数据类型。
虽然有帮助,我没有发现在现有的响应的干净和简单的解决方案的彩色输出转换var_dump()
到人类可读的输出转换成字符串没有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, ['=>' => '=>']));
}
返回下面的字符串不错:
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)
希望它可以帮助别人。
从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 }