Answers:
使用输出缓冲:
<?php
ob_start();
var_dump($someVar);
$result = ob_get_clean();
?>
strip_tags()
,这将仅返回类型和值。
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*
遇到循环引用时。
int(1)
而var_export仅打印出1
。
var_export
实际上对于调试而言并没有更好的效果,因为您无法在浏览器中搜索(int)
或(字符串)等。它还会将大量信息整理到一个很小的空间中,请尝试:var_export(''); var_export('\'');
。最重要的是,为PHP致命错误做好准备:嵌套级别太深-递归依赖项?在第75行的C:\ path \ file.php中
您也可以这样做:
$dump = print_r($variable, true);
print_r
在可能的地方使用,但是不幸的是有时它不能提供足够的信息。举例来说,因为它强制转换成字符串,其中就可以了,既false
和null
显示为空字符串。如果我在意这两者之间的差异,我会勉强诉诸于var_dump
或var_export
。
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();
}
也echo json_encode($dataobject);
可能有帮助
json_encode
将不会包含所有数据var_dump
(例如,作为变量类型)。以不同的格式json_encode
输出与相同的信息print_R
。
var_dump
。他还说,该print_R
信息不足以满足他的需要。json_encode
和提供的信息没有真正的区别print_r
-只有数据格式不同。鉴于此,如果print_r
不足,则为json_encode
。请不要再抱怨低票了。显然,这不只是随机点击,所以要处理它。
此函数显示有关一个或多个表达式的结构化信息,包括其类型和值。
因此,这是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 '';
}
$argc
正如@hanshenrik指出的那样,此处的检查是不必要的,而且可以说是不正确的,一旦删除该检查,您真正添加的就是call_user_func_array
and func_get_args
调用。
以下是作为功能的完整解决方案:
function varDumpToString ($var)
{
ob_start();
var_dump($var);
return ob_get_clean();
}
这可能有点题外话。
我正在寻找一种将此类信息写入我的PHP-FPM容器的Docker日志的方法,并提出了以下代码段。我确信Docker PHP-FPM用户可以使用它。
fwrite(fopen('php://stdout', 'w'), var_export($object, true));
file_put_contents('php://stdout',var_export($object, true),FILE_APPEND);
我真的很喜欢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, ['=>' => '=>']));
}
返回下面的漂亮字符串:
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 }