我有这段代码:
<?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;} }
} ?>
对于我得到的每个查询:“值1,值2,值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;
} }} ?>
答案 0 :(得分:0)
更新回答:
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)
答案 1 :(得分:0)
您的输出正确但日期格式无法正确显示,因为您需要对代码进行细微更改
if($i == 1) { $class = 'Data: '; }
在此处添加日期格式
if($i == 1) { $class = 'Data: ';
$date = new DateTime($data);
$data = $date->format('Y-m-d');
}