如何使用 php 将数组写入 csv 文件内容?

How to write an array as csv file content using php?

我正在将一个包含希伯来语的 CSV 文件导入到我的站点 language.While 在记事本中打开 CSV 文件,希伯来语内容未包含在引号中。不在引号中的内容不会在我的网站上阅读。 在上传的过程中,这个 csv 文件被移动到另一个 file.To 用双引号将希伯来语内容括起来我尝试了以下代码,但文件没有更新。

$fileHandler = fopen('IMPORT_193', 'rw');
        while (($buffer = fgets($fileHandler))) 
        {
        $v=explode(',',$buffer);

        for($i=0;$i<count($v);$i++)
        {

            $val=trim($v[$i],'"');
            $v1[]= '"'.$val.'"';

        }

        fputcsv($fileHandler, $v1);
        }

我想用带引号的 CSV 新值更新文件中的当前内容。有没有什么办法可以把CSV文件中的内容用引号括起来?等你的回复!

你不能(至少在这个例子中)同时读取和写入同一个文件。 试试这个:

$fileRead = fopen('IMPORT_193', 'r');
$tempFile = tempnam(sys_get_temp_dir(), 'CSVIMPORT');
$fileWrite = fopen($tempFile, 'w');
while(!feof($fileRead)) {
  $data = fgetcsv($fileRead);
  foreach($data as $key=>$value) {
    if(!is_numeric($value)) {
      $data[$key] = '"'.$value.'"';
    }
  }
  fputcsv($fileWrite, $data);
}
fclose($fileRead);
fclose($fileWrite);
rename($tempFile, 'IMPORT_193');

这应该可以解决问题。我没有测试过这个。并且您需要具有覆盖 IMPORT_193 文件的权限。