1

我想删除Upload, 并将列中的 0 更改为 888 qty,以下是我的代码,它使csv文件内容混乱。如何更正我的代码。谢谢你

 $dir   = getcwd();
   $files = scandir($dir);
   foreach ($files as $file)
   {
       $parts = pathinfo($file);
       if($parts['extension']!="csv") continue;
       if (($handle = fopen($file, "r")) !== FALSE)
       {
           $new_content =  implode(',', fgetcsv($handle, 1000, ","))."\n";
           while (($data = fgetcsv($handle, 1000, ",")) !== FALSE)
           {
               $data[12]=substr($data[12],9);
               $data[13]=substr($data[13],9);
               $data[14]=substr($data[14],9);
               $data[42]=888;
               $new_content .= implode(',', $data)."\n";
           }
           fclose($handle);
        file_put_contents($file, $new_content);
       }
   }

测试 csv 文件 http://phplist.xxmn.com/women.csv

4

1 回答 1

1

这是因为 .csv 文件的第一行超过 1000 个字符。如果您提前不确定每行有多大,我建议您这样做:

$data = fgetcsv($handle, 0, ','); // >= PHP 5.0.4

或者

$data = fgetcsv($handle, 4096, ',');

第一个选项可能会减慢处理速度,但可能可以忽略不计。

您还应该考虑使用fputcsv来编写输出。

$dir   = getcwd();
$files = scandir($dir);
foreach ($files as $file) {
   $parts = pathinfo($file);
   if ($parts['extension']!="csv") {
       continue;
   }
   if (false === ($outfile = fopen("$file.tmp", "w"))) {
       continue;
   }
   if (($handle = fopen($file, "r")) !== FALSE) {
       fputcsv($outfile, fgetcsv($handle, 4096, ","));

       while (($data = fgetcsv($handle, 4096, ",")) !== FALSE) {
           $data[12]=substr($data[12],9);
           $data[13]=substr($data[13],9);
           $data[14]=substr($data[14],9);
           $data[42]=888;
           fputcsv($outfile, $data);
       }
       fclose($handle);
       fclose($outfile);
       if (false === rename("$file.tmp", $file)) {
           die("Could not rename temporary file");
       }
   }
}
于 2012-05-08T06:04:19.990 回答