格式化 FOR 循环输出每 3 个结果

Formatting FOR Cycle Output every 3 results

我有这个代码:

<?php
$db = JFactory::getDBO(); $db->setQuery("SELECT data, numero, totale
FROM generico_fatturazione_fatture_clienti WHERE documento = '4' 
AND data BETWEEN (SELECT dalla_data_ FROM statistiche_andamento_aziendale WHERE id = 1) 
AND (SELECT alla_data_ FROM statistiche_andamento_aziendale WHERE id = 1)");
$risultato = $db->loadObjectList();
if ($risultato == null) {echo '<b>0</b>';}
elseif ($risultato == 0) {echo '<b>0</b>';}
else { echo '<br>';
foreach($risultato as $value) {foreach($value as $key => $data){ echo $data;} }
} ?>

对于我得到的每个查询:"Value 1, Value 2, Value 3" 所以我得到了值:"data, numero, totale"。 有没有办法获取每 3 个结果的列表,格式如下:

FIRST RESULT:
 - Data: Value 1
 - Numero: Value 2
 - Totale: Value 3
SECOND RESULT:
 - Data: Value 1
 - Numero: Value 2
 - Totale: Value 3

等等等等?

我已经修复了代码,现在输出看起来更容易接受了,我只需要将第一个值(数据字符串)转换为另一种格式:

<?php $db = JFactory::getDBO(); $db->setQuery("
SELECT data, numero, totale
FROM generico_fatturazione_fatture_clienti WHERE documento = '4' 
AND data BETWEEN (SELECT dalla_data_ FROM statistiche_andamento_aziendale WHERE id = 1) 
AND (SELECT alla_data_ FROM statistiche_andamento_aziendale WHERE id = 1)");
$risultato = $db->loadObjectList();
if ($risultato == null) {echo '<b>0</b>';}
elseif ($risultato == 0) {echo '<b>0</b>';}
else { echo '<br>';
foreach($risultato as $value) {
$i= 0;
foreach($value as $key => $data){ 
$i++;

if($i == 1) { $class = 'Data: '; }
elseif($i == 2) { $class = 'Fattura Numero: '; }
elseif($i == 3) { $class = 'Totale (€): '; }
if ($i == 3) {$newline = '<br>';} else {$newline = null;}
$virgola = ',';

echo $class.' <b> '.$data.$virgola.' </b>'.$newline;
} }} ?>

更新的答案:

foreach($risultato as $value) {
    echo '- Data: ' . $value->data . PHP_EOL;
    echo '- Numero: ' . $value->numero . PHP_EOL;
    echo '- Totale: ' . $value->totale . PHP_EOL;
    echo '-------------' . PHP_EOL;
}

这行得通吗?如果不提供 print_r($risultato)

的输出

您的输出是正确的,但日期格式无法正确显示,您需要对代码进行微小的更改

if($i == 1) { $class = 'Data: '; }

在此处添加日期格式

if($i == 1) { $class = 'Data: '; 
     $date = new DateTime($data);
     $data = $date->format('Y-m-d'); 
}