警告:prev() 期望参数 1 是数组,给定字符串


Warning: prev() expects parameter 1 to be array, string given in

我正在尝试了解如何修复此错误。

警告:prev() 期望参数 1 是数组,字符串在

它在下面的 if 语句中。 发生这种情况是因为第一个值没有前一个值,我需要处理这种情况吗? 奇怪的是,这在常规.php中有效,但在我现在拥有的框架中却不起作用。

我正在尝试根据为查询返回的结果集生成 XML 文件。 (我愿意接受更好的想法)

    $export.= '<Campaigns>';
    while ($line = mysql_fetch_assoc($result) ) {
        //echo '<Email Timestamp="' . $line['EmailTimeStamp'] . '" ';
        $export.=  '<Campaign Info="' . $line['EmailTrackingNumber'] . '" EmailId="' .$line['EmailId'] . '">';
        $export.=  '<Emails>';
                if (prev($line['EmailTrackingNumber']) == current($line['EmailTrackingNumber'])) {
                    $export.=  '<Email Timestamp="' . $line['EmailTimeStamp'] . '" ';
                    $export.=  'City="' . $line['City'] . '" ';
                    $export.=  'Zip="' . $line['Zip'] . '"';
                }
        $export.=  '</Emails></Campaign>';
        }
    $export.= '</Campaigns></EmailTrackingData>';
    //echo $export;
    file_put_contents('DateOfFile-export.xml', $export);

prev($line['EmailTrackingNumber'])

不是数组,而是字符串。这

prev($line)

更有意义。它返回当前条目之前的数组条目 $line

但我想你想将上一个记录与当前记录进行比较。但这不是这样工作的。您只能访问当前记录的列。您必须暂时保存最后一条记录。

$export.= '<Campaigns>';
$lastLine = null;
while ($line =  mysql_fetch_assoc($result)) {
    //echo '<Email Timestamp="' . $line['EmailTimeStamp'] . '" ';
    $export.=  '<Campaign Info="' . $line['EmailTrackingNumber'] . '" EmailId="' .$line['EmailId'] . '">';
    $export.=  '<Emails>';
    if ($lastLine['EmailTrackingNumber'] == $line['EmailTrackingNumber']) {
        $export.=  '<Email Timestamp="' . $line['EmailTimeStamp'] . '" ';
        $export.=  'City="' . $line['City'] . '" ';
        $export.=  'Zip="' . $line['Zip'] . '"';
    }
    $export.=  '</Emails></Campaign>';
    $lastLine = $line;
}
$export.= '</Campaigns></EmailTrackingData>';
//echo $export;
file_put_contents('DateOfFile-export.xml', $export);