我的PHP脚本花费太长时间来回显文件中的数据。似乎我出错了一些循环并且处理时间过长。可以请任何人查看我的代码并让我知道我哪里出错了? 我的任务是遍历JSON数据数组并回显XML标记中的数据。 我的json数组如下所示 [[“GENERIC SALES PRICE”,“”],[“REGION”,“SALE PRICE”],[“AMERICA”,“260,000”],[“ASIA”,“340,000”],..等等
$fp = fopen("data_save2.json", "r");
$inp=file_get_contents("data_save2.json");
fclose($fp);
$inp=json_decode($inp);
$inp_info=$inp;
$start_row=0;
$start_col=0;
for($i=0; $i <= $inp_info; $i++) {
for($j=0; $j <= $inp_info; $j++) {
if ($inp_info[$i][$j]=='GENERIC SALES PRICE') {
$start_row=$i+1;
$start_col=$j;
}
$row_index=$start_row;
$rows_of_data=0;
while($inp_info[$row_index][$start_col]!=''){
$rows_of_data = $rows_of_data+1;
$row_index = $row_index+1;}
}
}
$dir = "C:/../data/GenericSalePrice.xml";
$fp = fopen($dir, 'w');
fwrite($fp,'<?xml version="1.0" encoding="UTF-8" standalone="yes"?>');
fwrite($fp,"\n");
fwrite($fp,'<generic-sales-price xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">');
fwrite($fp,"\n");
for($j=0; $j<=$rows_of_data; $j++){
fwrite($fp,"\t<sale-price>\n");
$region = $inp_info[$start_row+$j][$start_col];
fwrite($fp, "\t\t<region>");
fwrite($fp,"$region");
fwrite($fp, "</region>\n");
$price =$inp_info[$start_row+$j][$start_col+1];
fwrite($fp, "\t\t<price>");
fwrite($fp, "$price");
fwrite($fp, "</price>\n");
fwrite($fp, "\t</sale-price>\n");
}
fwrite($fp, "</generic-sales-price>");
fclose($fp);
请帮我这个, 提前致谢
答案 0 :(得分:0)
警告 - 在这里走出困境并将其作为我的答案而不进行测试,以确认没有适当数据的速度或语法。
$xml_file = "C:/../data/GenericSalePrice.xml";
$header =
<<<EOT
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<generic-sales-price xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
EOT;
$body = '';
for($j=0; $j<=$rows_of_data; $j++) {
$region = $inp_info[$start_row+$j][$start_col];
$price = $inp_info[$start_row+$j][$start_col+1];
$temp_body =
<<<EOT
<sale-price>
<region>
{$region}
</region>
<price>
{$price}
</price>
</sale-price>
EOT;
$body .= $temp_body;
}
$footer = "</generic-sales-price>";
$string = $header . $body . $footer;
file_put_contents($xml_file, $string);
答案 1 :(得分:0)
发现错误.. 我正在使用
for($i=0; $i <= $inp_info; $i++) {
for($j=0; $j <= $inp_info; $j++) {
现在,我已将其更改为
for($i=0; $i <= count($inp_info); $i++) {
for($j=0; $j <= count($inp_info); $j++) {
它开始工作了。感谢大家的时间和精力