我得到了以下php代码,该代码当前正在处理一个包含每行(动物>宠物用品>鸟用品)的数据的txt文件和我正在重新格式化它以将其与我的数据库一起使用。如何将此PHP代码处理的数据保存为CSV或TXT文件
我想要做的是将输出数据保存为CSV或TXT文件,或者将其保存到我的浏览器中,就像它现在一样。请注意,脚本中有3个打印部分。
任何帮助或建议将不胜感激。
set_time_limit(0);
//read and process txt.txt
$file_handle = fopen("txt.txt", "rb");
$j = 0;
while (!feof($file_handle)){
$line = fgets($file_handle);
$parts = explode('>', $line);
if(count($parts) == 1){
$parts[0] = trim($parts[0]);
$db[$j] = array("CatName"=>$parts[0], "CatID"=>$j+1, "PID"=>0, "Level"=>1);
print $db[$j]["CatName"]."\t".$db[$j]["CatID"]."\t".$db[$j]["PID"]."\t".$db[$j]["Level"]."\r\n";
} else {
$i =0;
$no = count($parts);
$t = $no-1;
while($t != -1){
$parts[$t] = trim($parts[$t]);
$t = $t-1;
}
$k = $j-1;
while($i != $j){
while($k > -1){
if(strcmp($parts[$i], $db[$k]["CatName"]) == 0){
$flag = 1;
}
$k = $k-1;
}
if($flag == 1){
if(strcmp($parts[$no-2], $db[$i]["CatName"]) == 0){
$found = $i;
}
}
$i = $i+1;
}
if($flag == 1){
$db[$j] = array("CatName"=>$parts[$no-1], "CatID"=>$j+1, "PID"=>$db[$found]["CatID"], "Level"=>$no);
print $db[$j]["CatName"]."\t".$db[$j]["CatID"]."\t".$db[$j]["PID"]."\t".$db[$j]["Level"]."\r\n";
}
if($flag == 0 && $no == 1){
$db[$j] = array("CatName"=>$parts[$no-1], "CatID"=>$j+1, "PID"=>0, "Level"=>$no);
print $db[$j]["CatName"]."\t".$db[$j]["CatID"]."\t".$db[$j]["PID"]."\t".$db[$j]["Level"]."\r\n";
}
}
$j = $j+1;
$flag = 0;
}
fclose($file_handle);
BTW:我已经用刺来代替打印语句,然后它们的输出保存到我的csv文件,但它不会工作,它只返回空值。 例中使用:
//print $db[$j]["CatName"]."\t".$db[$j]["CatID"]."\t".$db[$j]["PID"]."\t".$db[$j]["Level"]."\r\n";
$csv_data .= $db[$j]["CatName"]."\t".$db[$j]["CatID"]."\t".$db[$j]["PID"]."\t".$db[$j]["Level"]."\r\n";
参见[输出缓冲( http://php.net/manual/en/book.outcontrol.php)。 –
会查看它,但页面没有给出一个很好的例子,如何正确使用输出控制 – luiavag