0

我有一个要导出到 CSV 文件的数组,现在我知道有一个 fputcsv 函数,但我使用的是 PHP 5.0.4 版本,所以这不是我的选择。

我可以使用其他方法吗?

4

3 回答 3

1

您可以为此使用 polyfill。编写您的代码,就好像您在支持fputcsvphp 块中的注释的系统上一样(带有一些轻微的框架代码),但包括这个(从http://www.php.net/manual/en/function 复制并稍作修改。 fputcsv.php#56827 )

<?php
if (!function_exists(fputcsv)){
 function fputcsv($filePointer,$dataArray,$delimiter,$enclosure)
  {
  // Write a line to a file
  // $filePointer = the file resource to write to
  // $dataArray = the data to write out
  // $delimeter = the field separator

  // Build the string
  $string = "";

  // No leading delimiter
  $writeDelimiter = FALSE;
  foreach($dataArray as $dataElement)
   {
    // Replaces a double quote with two double quotes
    $dataElement=str_replace("\"", "\"\"", $dataElement);

    // Adds a delimiter before each field (except the first)
    if($writeDelimiter) $string .= $delimiter;

    // Encloses each field with $enclosure and adds it to the string
    $string .= $enclosure . $dataElement . $enclosure;

    // Delimiters are used every time except the first.
    $writeDelimiter = TRUE;
   } // end foreach($dataArray as $dataElement)

  // Append new line
  $string .= "\n";

  // Write the string to the file
  fwrite($filePointer,$string);
  }
}
?>
于 2013-06-05T14:31:22.223 回答
0

假设您有一个$Data数组,其中包含每个注册表(或行)的单独数组,您可以试试这个:

$Delimiter = '"';
$Separator = ','
foreach($Data as $Line)
{   
 fwrite($File, $Delimiter.
        implode($Delimiter.$Separator.$Delimiter, $Line).$Delimiter."\n");
}

$File您的文件的句柄在哪里。放入$Delimiter,您要放置在每个字段周围的字符,以及 in $Separator,要在字段之间使用的字符。

于 2013-06-05T14:39:05.070 回答
0

我从@Orangepill 中获取了解决方案,并以几种方式对其进行了重构/简化。如果您希望将每个字段都包含在内,这也可能会变得很方便,而默认 php 实现中并非如此。

function fputcsv_custom($handle, $fields, $delimiter = ",", $enclosure = '"', $escape_char = "\\") {
    $field_arr = [];

    foreach($fields as $field) {
        $field_arr[] = $enclosure . str_replace($enclosure, $escape_char . $enclosure, $field) . $enclosure;
    }

    fwrite($handle, implode($delimiter, $field_arr) . "\n");
}
于 2021-03-17T22:16:58.097 回答