2013-03-08 24 views
6

我已经搜索和搜索,并进行了广泛的调试,并为我的生活找不到为什么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文件全部是(正如你在上面的调试代码中看到的那样)“这个文件已经打开并且正在工作。”

任何人可能有任何想法将不胜感激!

非常感谢!

旅行

+0

您应该记录fputcsv调用的返回值。如果成功则返回写入的字节数,否则返回布尔值false。由于你根本没有得到任何响应代码,所以在循环结尾可能是一个布尔型的错误,它通常是不可打印的。 – 2013-03-08 18:26:59

回答

5

的第二个参数fputcsv()应该是一个数组,但你传递一个字符串,因为你是循环的字符串数组和单独写每一个。

我怀疑你只是想这样的:

$myfile = fopen('/blog/pdm_twitter_ouptut.csv', 'a+'); 
fputcsv($myfile, $posts_meta); 

如果你想写列标题为好,这我猜你可能会因为你使用的关联数组,你可能需要一些逻辑更是这样的:

$filePath = '/blog/pdm_twitter_ouptut.csv'; 

$exists = file_exists($filePath) && filesize($filePath) > 0; 

$myfile = fopen($filePath, 'a+'); 

if (!$exists) { 
    fputcsv($myfile, array_keys($posts_meta)); 
} 

fputcsv($myfile, $posts_meta); 
+0

啊,就是这样!你很漂亮!非常感谢,祝你周末愉快! - 旅行 – user2149399 2013-03-08 18:37:08

+3

不要接受答案!他不需要代表!他只是这样做来帮助人们! – rdlowrey 2013-03-08 18:39:30

+0

哈哈!谢谢大家! – user2149399 2013-03-08 20:34:13