我已经搜索和搜索,并进行了广泛的调试,并为我的生活找不到为什么fputcsv不为我工作。在PHP中的fputcsv不会写入文件
我可以成功打开.csv文件并写入它。
我的调试证明数组已正确加载,并且foreach循环正常工作。但是,fputcsv函数根本没有写任何东西。我删除了所有可能导致问题的字符串,例如URL等,但它仍然不会写入。
我是唯一有权访问此环境的人,所以我知道它不是文件锁冲突。我可以创建该文件并写入,因此我知道这不是权限问题。而且,我从foreach循环获取调试输出,所以我知道这不是数组或循环的问题。
我会提供我的代码和下面的调试日志...
$posts_meta = array(
'twitter_title' => $this_title,
'twitter_brandtag' => $this_brandtag,
'twitter_hashtags' => $this_hashtags,
'twitter_iterations' => $this_iteration,
'twitter_timing' => $this_timing,
'twitter_time' => $this_time,
'twitter_id' => $post_id,
);
// Debuging
file_put_contents("/blog/debug.txt", "About to write CSV file.\n", FILE_APPEND);
file_put_contents("/blog/debug.txt", print_r($posts_meta, true)."\n", FILE_APPEND);
$myfile = fopen('/blog/pdm_twitter_ouptut.csv', 'a+');
// More debugin
file_put_contents("/blog/debug.txt", "myfile handle = ".$myfile."\n", FILE_APPEND);
fwrite($myfile, "This file is open and working.\r\n");
foreach ($posts_meta as $fields){
$fresponse = fputcsv($myfile, $fields);
// A little more debugging...
file_put_contents("/blog/debug.txt", $fields."\n", FILE_APPEND);
}
fclose($myfile);
// And more debugging
file_put_contents("/blog/debug.txt", "fputcsv response = ".$fresponse."\n", FILE_APPEND);
file_put_contents("/blog/debug.txt", "Just closed CSV file.", FILE_APPEND);
这里是生成的调试日志...
About to write CSV file.
Array
(
[twitter_title] => World Stocks Up As US Jobs, China Exports Improve
[twitter_brandtag] => - FP test 9
[twitter_hashtags] => #Economy #Markets #Business #Investing #Stocks
[twitter_iterations] => 12
[twitter_timing] => 240
[twitter_time] => 2013-03-08 07:55:24
[twitter_id] => 11051
)
myfile handle = Resource id #548
// Print-out of $fields here...
World Stocks Up As US Jobs, China Exports Improve
- FP test 9
#Economy #Markets #Business #Investing #Stocks
12
240
2013-03-08 07:55:24
11051
fputcsv response = // Hm!? I wonder why no response code?
Just closed CSV file.
出现在.csv文件全部是(正如你在上面的调试代码中看到的那样)“这个文件已经打开并且正在工作。”
任何人可能有任何想法将不胜感激!
非常感谢!
旅行
您应该记录fputcsv调用的返回值。如果成功则返回写入的字节数,否则返回布尔值false。由于你根本没有得到任何响应代码,所以在循环结尾可能是一个布尔型的错误,它通常是不可打印的。 – 2013-03-08 18:26:59