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

时间:2013-11-07 14:16:41

标签: php

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

警告: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);

1 个答案:

答案 0 :(得分:0)

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);