以可读/分层格式显示数组

时间:2011-03-22 14:50:51

标签: php sql

以下是为我的数组提取数据的代码

<?php
    $link = mysqli_connect('localhost', 'root', '', 'mutli_page_form');

    $query = "SELECT * FROM wills_children WHERE will=73";

    $result = mysqli_query($link, $query) or die(mysqli_error($link));

    if ($result = mysqli_query($link, $query)) {

    /* fetch associative array */
    if($row = mysqli_fetch_assoc($result)) {
        $data = unserialize($row['children']);
    }

    /* free result set */
    mysqli_free_result($result);
    }
?>

当我使用print_r($ data)时,它读作:

Array ( [0] => Array ( [0] => Natural Chlid 1 [1] => Natural Chlid 2 [2] => Natural Chlid 3 ) ) 

我希望它读作:

自然孩子1 自然孩子2
自然孩子3

19 个答案:

答案 0 :(得分:391)

而不是

print_r($data);

print "<pre>";
print_r($data);
print "</pre>";

答案 1 :(得分:53)

print("<pre>".print_r($data,true)."</pre>");

答案 2 :(得分:45)

我有一个基本功能:

function prettyPrint($a) {
    echo "<pre>";
    print_r($a);
    echo "</pre>";
}

prettyPrint($data);

编辑:优化功能

function prettyPrint($a) {
    echo '<pre>'.print_r($a,1).'</pre>';
}

编辑:具有自定义标记支持的Moar优化功能

function prettyPrint($a, $t='pre') {echo "<$t>".print_r($a,1)."</$t>";}

答案 3 :(得分:28)

试试这个:

foreach($data[0] as $child) {
   echo $child . "\n";
}

取代print_r($data)

答案 4 :(得分:12)

我认为var_export(),被遗忘的var_dump()兄弟拥有最佳输出 - 它更紧凑:

echo "<pre>";
var_export($menue);
echo "</pre>";

顺便说一下:使用<pre>并不是必需的。当您查看网页的源代码时,var_dump()var_export()已经格式化。

答案 5 :(得分:8)

如果有人需要查看数组太酷;)使用此方法..这将打印到您的浏览器控制台

function console($obj)
{
    $js = json_encode($obj);
    print_r('<script>console.log('.$js.')</script>');
}

你可以像这样使用..

console($myObject);

输出就像这样..太酷了呃!!

enter image description here

答案 6 :(得分:3)

print_r()主要用于调试。如果要以该格式打印,请循环遍历数组,然后打印出元素。

foreach($data as $d){
  foreach($d as $v){
    echo $v."\n";
  }
}

答案 7 :(得分:3)

foreach($array as $v) echo $v, PHP_EOL;

更新:更复杂的解决方案是:

 $test = [
    'key1' => 'val1',
    'key2' => 'val2',
    'key3' => [
        'subkey1' => 'subval1',
        'subkey2' => 'subval2',
        'subkey3' => [
            'subsubkey1' => 'subsubval1',
            'subsubkey2' => 'subsubval2',
        ],
    ],
];
function printArray($arr, $pad = 0, $padStr = "\t") {
    $outerPad = $pad;
    $innerPad = $pad + 1;
    $out = '[' . PHP_EOL;
    foreach ($arr as $k => $v) {
        if (is_array($v)) {
            $out .= str_repeat($padStr, $innerPad) . $k . ' => ' . printArray($v, $innerPad) . PHP_EOL;
        } else {
            $out .= str_repeat($padStr, $innerPad) . $k . ' => ' . $v;
            $out .= PHP_EOL;
        }
    }
    $out .= str_repeat($padStr, $outerPad) . ']';
    return $out;
}

echo printArray($test);

打印出来:

    [
        key1 => val1
        key2 => val2
        key3 => [
            subkey1 => subval1
            subkey2 => subval2
            subkey3 => [
                subsubkey1 => subsubval1
                subsubkey2 => subsubval2
            ]
        ]
    ]

答案 8 :(得分:3)

这可能是一个更简单的解决方案:

echo implode('<br>', $data[0]);

答案 9 :(得分:2)

我假设有人使用print_r进行调试。然后我建议使用像Kint这样的库。这允许以可读格式显示大数组:

 new Handler().postDelayed(new Runnable() {
       @Override
       public void run() {

          textwel.setText("Welcome");
       }

   }, 4000);

enter image description here

答案 10 :(得分:1)

<?php 
//Make an array readable as string
function array_read($array, $seperator = ', ', $ending = ' and '){
      $opt = count($array);
      return $opt > 1 ? implode($seperator,array_slice($array,0,$opt-1)).$ending.end($array) : $array[0];
}
?>

我用它来向访问者展示一个漂亮的印刷阵列

答案 11 :(得分:1)

使用var_dump函数在php中打印格式化数组的非常好的方法。

 $a = array(1, 2, array("a", "b", "c"));
 var_dump($a);

答案 12 :(得分:1)

我用它来获取密钥及其值     $ qw = mysqli_query($ connection,$ query);

while ( $ou = mysqli_fetch_array($qw) )
{
    foreach ($ou as $key => $value) 
    {
            echo $key." - ".$value."";
    }
    echo "<br/>";
}

答案 13 :(得分:1)

我会使用在线工具。

答案 14 :(得分:1)

用于快速简便的JSON表示的单行程序:

    echo json_encode($data, JSON_PRETTY_PRINT);

如果已经为项目使用composer,则需要symfony / yaml和:

    echo Yaml::dump($data);

答案 15 :(得分:0)

echo '<pre>';
foreach($data as $entry){
    foreach($entry as $entry2){
        echo $entry2.'<br />';
    }
}

答案 16 :(得分:0)

对于单个阵列,您可以使用implode,它可以打印更清晰的结果。

<?php
$msg = array('msg1','msg2','msg3');
echo implode('<br />',$msg);
echo '<br />----------------------<br/>';

echo nl2br(implode("\n",$msg));
echo '<br />----------------------<br/>';
?>

对于多维数组,您需要与某种循环结合使用。

<?php
$msgs[] = $msg;
$msgs[] = $msg;
$msgs[] = $msg;
$msgs[] = $msg;
$msgs[] = $msg;
foreach($msgs as $msg) {
    echo implode('<br />',$msg);
    echo '<br />----------------------<br/>';
}
?>

答案 17 :(得分:0)

这试图改善控制台应用程序中的print_r()输出格式:

function pretty_printr($array) {

  $string = print_r($array, TRUE);

  foreach (preg_split("/((\r?\n)|(\r\n?))/", $string) as $line) {

    $trimmed_line = trim($line);

    // Skip useless lines.
    if (!$trimmed_line || $trimmed_line === '(' || $trimmed_line === ')' || $trimmed_line === 'Array') {
      continue;
    }

    // Improve lines ending with empty values.
    if (substr_compare($trimmed_line, '=>', -2) === 0) {
      $line .=  "''";
    }

    print $line . PHP_EOL;
  }
}

示例:

[activity_score] => 0
[allow_organisation_contact] => 1
[cover_media] => Array
        [image] => Array
                [url] => ''
        [video] => Array
                [url] => ''
                [oembed_html] => ''
        [thumb] => Array
                [url] => ''
[created_at] => 2019-06-25T09:50:22+02:00
[description] => example description
[state] => published
[fundraiser_type] => anniversary
[end_date] => 2019-09-25
[event] => Array
[goal] => Array
        [cents] => 40000
        [currency] => EUR
[id] => 37798
[your_reference] => ''

答案 18 :(得分:0)

将深层嵌套数组显示为表

print_r_as_table($post_result);

function print_r_as_table($my_array) {

    if (is_array($my_array)) {
        echo "<table border=1 cellspacing=0 cellpadding=3 >";
        echo '<tr><td colspan=2 style="background-color:lightgrey;"><strong><font color=blue>ARRAY</font></strong></td></tr>';

        foreach ($my_array as $k => $v) {
                echo '<tr><td valign="top" style="width:40px;background-color:#fff;">';
                echo '<strong>' . $k . "</strong></td><td>";
                print_r_as_table($v);
                echo "</td></tr>";
        }
        echo "</table>";
        return;
    }
    echo $my_array;
}

Example of view, how it look on use