Voici le code pour extraire les données de mon tableau
<?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);
}
?>
Quand j'utilise print_r ($ data), cela se lit comme suit:
Array ( [0] => Array ( [0] => Natural Chlid 1 [1] => Natural Chlid 2 [2] => Natural Chlid 3 ) )
Je voudrais qu'il se lise comme:
Enfant naturel 1
Enfant naturel 2
Enfant naturel 3
Essaye ça:
foreach($data[0] as $child) {
echo $child . "\n";
}
à la place de print_r($data)
Au lieu de
print_r($data);
essayer
print "<pre>";
print_r($data);
print "</pre>";
print("<pre>".print_r($data,true)."</pre>");
J'ai une fonction basique:
function prettyPrint($a) {
echo "<pre>";
print_r($a);
echo "</pre>";
}
prettyPrint($data);
EDIT: Fonction optimisée
function prettyPrint($a) {
echo '<pre>'.print_r($a,1).'</pre>';
}
EDIT: Moar Fonction optimisée avec prise en charge des balises personnalisées
function prettyPrint($a, $t='pre') {echo "<$t>".print_r($a,1)."</$t>";}
Je pense que var_export()
, le frère oublié de var_dump()
a le meilleur rendement - il est plus compact:
echo "<pre>";
var_export($menue);
echo "</pre>";
Soit dit en passant: il n'est pas toujours nécessaire d'utiliser <pre>
. var_dump()
et var_export()
sont déjà formatés lorsque vous consultez le code source de votre page Web.
si quelqu'un a besoin d'afficher des tableaux si cool;) utilisez cette méthode .. ceci sera imprimé sur la console de votre navigateur
function console($obj)
{
$js = json_encode($obj);
print_r('<script>console.log('.$js.')</script>');
}
vous pouvez utiliser comme ça ..
console($myObject);
La sortie sera comme ça .. tellement cool hein !!
Cela peut être une solution plus simple:
echo implode('<br>', $data[0]);
foreach($array as $v) echo $v, PHP_EOL;
UPDATE: Une solution plus sophistiquée serait:
$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);
Cela imprime:
[
key1 => val1
key2 => val2
key3 => [
subkey1 => subval1
subkey2 => subval2
subkey3 => [
subsubkey1 => subsubval1
subsubkey2 => subsubval2
]
]
]
Je suppose qu'on utilise print_r pour le débogage. Je suggérerais alors d’utiliser des bibliothèques comme Kint . Cela permet d'afficher de grands tableaux dans un format lisible:
$data = [['Natural Child 1', 'Natural Child 2', 'Natural Child 3']];
Kint::dump($data, $_SERVER);
print_r()
est principalement destiné au débogage. Si vous souhaitez l'imprimer dans ce format, parcourez le tableau et imprimez les éléments.
foreach($data as $d){
foreach($d as $v){
echo $v."\n";
}
}
J'utilise ceci pour obtenir les clés et leurs valeurs $ qw = mysqli_query ($ connection, $ query);
while ( $ou = mysqli_fetch_array($qw) )
{
foreach ($ou as $key => $value)
{
echo $key." - ".$value."";
}
echo "<br/>";
}
Très bonne façon d’imprimer un tableau formaté en php, en utilisant la fonction var_dump.
$a = array(1, 2, array("a", "b", "c"));
var_dump($a);
Je voudrais simplement utiliser des outils en ligne.
faites d'abord print_r (your_array)
Deuxième copie du résultat et collage dans http://phillihp.com/toolz/php-array-beautifier/
One-Liner pour une représentation JSON simple et rapide:
echo json_encode($data, JSON_PRETTY_PRINT);
Si vous utilisez déjà composer pour le projet, utilisez symfony/yaml et:
echo Yaml::dump($data);
echo '<pre>';
foreach($data as $entry){
foreach($entry as $entry2){
echo $entry2.'<br />';
}
}
Ceci tente d’améliorer le formatage de sortie de print_r()
dans les applications de console:
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;
}
}
Exemple:
[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] => ''
<?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];
}
?>
J'utilise ceci pour montrer un joli tableau imprimé à mes visiteurs
Pour les baies simples que vous pouvez utiliser imploser, l’impression est plus nette.
<?php
$msg = array('msg1','msg2','msg3');
echo implode('<br />',$msg);
echo '<br />----------------------<br/>';
echo nl2br(implode("\n",$msg));
echo '<br />----------------------<br/>';
?>
Pour les tableaux multidimensionnels, vous devez combiner une sorte de boucle.
<?php
$msgs[] = $msg;
$msgs[] = $msg;
$msgs[] = $msg;
$msgs[] = $msg;
$msgs[] = $msg;
foreach($msgs as $msg) {
echo implode('<br />',$msg);
echo '<br />----------------------<br/>';
}
?>