Oto kod do pobierania danych dla mojej tablicy
<?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);
}
?>
Kiedy używam print_r ($ data), wygląda to tak:
Array ( [0] => Array ( [0] => Natural Chlid 1 [1] => Natural Chlid 2 [2] => Natural Chlid 3 ) )
Chciałbym to przeczytać jako:
Dziecko naturalne 1
Dziecko
naturalne 2 Dziecko naturalne 3
<?php foreach($data[0] as $child) { echo $child . "<br />"; }?>
to działało świetnie, dzięki Brian!<pre>print_r($data)</pre>
. Zawsze fajnie jest zobaczyć nowy komentarz do odpowiedzi sprzed 5 lat! :)Zamiast
print_r($data);
próbować
print "<pre>"; print_r($data); print "</pre>";
źródło
true
jako drugi parametr można przekazać print_r, aby uzyskać dane jakostring
. Teraz możeszreturn '<pre>'.print_r(User::all(), true);
z pliku tras.print("<pre>".print_r($data,true)."</pre>");
źródło
Mam podstawową funkcję:
function prettyPrint($a) { echo "<pre>"; print_r($a); echo "</pre>"; } prettyPrint($data);
EDYCJA: zoptymalizowana funkcja
function prettyPrint($a) { echo '<pre>'.print_r($a,1).'</pre>'; }
EDYCJA: Zoptymalizowana funkcja Moar z obsługą niestandardowych tagów
function prettyPrint($a, $t='pre') {echo "<$t>".print_r($a,1)."</$t>";}
źródło
echo '<pre>',print_r($a,1),'</pre>';
Myślę
var_export()
, że zapomniany bratvar_dump()
ma najlepsze wyjście - jest bardziej kompaktowy:echo "<pre>"; var_export($menue); echo "</pre>";
Przy okazji: nie zawsze jest to konieczne
<pre>
.var_dump()
ivar_export()
są już sformatowane, gdy spojrzysz na kod źródłowy swojej strony internetowej.źródło
jeśli ktoś potrzebuje przeglądać tablice takie fajne;) skorzystaj z tej metody .. to wypisze na konsoli twojej przeglądarki
function console($obj) { $js = json_encode($obj); print_r('<script>console.log('.$js.')</script>'); }
możesz używać w ten sposób ...
console($myObject);
Wynik będzie taki ... super eh !!
źródło
foreach($array as $v) echo $v, PHP_EOL;
AKTUALIZACJA : Bardziej wyrafinowanym rozwiązaniem byłoby:
$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);
To drukuje:
źródło
print_r()
służy głównie do debugowania. Jeśli chcesz wydrukować go w tym formacie, zapętlaj tablicę i wydrukuj elementy.foreach($data as $d){ foreach($d as $v){ echo $v."\n"; } }
źródło
$data
jest tablicą tablic.To może być prostsze rozwiązanie:
echo implode('<br>', $data[0]);
źródło
Zakładam, że do debugowania używa się print_r. Sugerowałbym wtedy korzystanie z bibliotek takich jak Kint . Pozwala to na wyświetlanie dużych tablic w czytelnym formacie:
$data = [['Natural Child 1', 'Natural Child 2', 'Natural Child 3']]; Kint::dump($data, $_SERVER);
źródło
<?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]; } ?>
Używam tego, aby pokazać odwiedzającym ładnie wydrukowaną tablicę
źródło
Bardzo fajny sposób na wydrukowanie sformatowanej tablicy w php, używając funkcji var_dump.
$a = array(1, 2, array("a", "b", "c")); var_dump($a);
źródło
Używam tego do uzyskiwania kluczy i ich wartości $ qw = mysqli_query ($ connection, $ query);
while ( $ou = mysqli_fetch_array($qw) ) { foreach ($ou as $key => $value) { echo $key." - ".$value.""; } echo "<br/>"; }
źródło
Po prostu użyłbym narzędzi online.
najpierw print_r (your_array)
Następnie skopiuj wynik i wklej w http://phillihp.com/toolz/php-array-beautifier/
źródło
Jedna linijka do szybkiej i łatwej reprezentacji JSON:
echo json_encode($data, JSON_PRETTY_PRINT);
Jeśli używasz już Composera do projektu, potrzebujesz symfony / yaml i:
echo Yaml::dump($data);
źródło
echo '<pre>'; foreach($data as $entry){ foreach($entry as $entry2){ echo $entry2.'<br />'; } }
źródło
W przypadku pojedynczych tablic można użyć implodu, co zapewnia czystszy wynik drukowania.
<?php $msg = array('msg1','msg2','msg3'); echo implode('<br />',$msg); echo '<br />----------------------<br/>'; echo nl2br(implode("\n",$msg)); echo '<br />----------------------<br/>'; ?>
W przypadku tablic wielowymiarowych musisz połączyć je z jakąś pętlą.
<?php $msgs[] = $msg; $msgs[] = $msg; $msgs[] = $msg; $msgs[] = $msg; $msgs[] = $msg; foreach($msgs as $msg) { echo implode('<br />',$msg); echo '<br />----------------------<br/>'; } ?>
źródło
To próbuje poprawić
print_r()
formatowanie danych wyjściowych w aplikacjach konsolowych: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; } }
Przykład:
[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] => ''
źródło