首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >PHP数组到CSV

PHP数组到CSV
EN

Stack Overflow用户
提问于 2012-10-28 18:46:35
回答 6查看 247.9K关注 0票数 126

我正在尝试将一组产品转换为CSV文件,但似乎没有计划。CSV文件很长,下面是我的代码:

代码语言:javascript
复制
for($i=0;$i<count($prods);$i++) {
$sql = "SELECT * FROM products WHERE id = '".$prods[$i]."'";
$result = $mysqli->query($sql);
$info = $result->fetch_array(); 
}

$header = '';

for($i=0;$i<count($info);$i++)  
  {
    $row = $info[$i];

    $line = '';
    for($b=0;$b<count($row);$b++)
    { 
    $value = $row[$b];                                      
        if ( ( !isset( $value ) ) || ( $value == "" ) )
        {
            $value = "\t";
        }
        else
        {
            $value = str_replace( '"' , '""' , $value );
            $value = '"' . $value . '"' . "\t";
        }
         $line .= $value;
        }
    $data .= trim( $line ) . "\n";
}
$data = str_replace( "\r" , "" , $data );

if ( $data == "" )
{
$data = "\n(0) Records Found!\n";                        
}

header("Content-type: application/octet-stream");
header("Content-Disposition: attachment; filename=your_desired_name.xls");
header("Pragma: no-cache");
header("Expires: 0");

array_to_CSV($data);


function array_to_CSV($data)
    {
        $outstream = fopen("php://output", 'r+');
        fputcsv($outstream, $data, ',', '"');
        rewind($outstream);
        $csv = fgets($outstream);
        fclose($outstream);
        return $csv;
    }

此外,头文件不会强制下载。我一直在复制和粘贴输出,并另存为.csv

编辑

问题已解决:

如果其他人也在寻找同样的东西,找到一种更好的方法:

代码语言:javascript
复制
$num = 0;
$sql = "SELECT id, name, description FROM products";
if($result = $mysqli->query($sql)) {
     while($p = $result->fetch_array()) {
         $prod[$num]['id']          = $p['id'];
         $prod[$num]['name']        = $p['name'];
         $prod[$num]['description'] = $p['description'];
         $num++;        
    }
 }
$output = fopen("php://output",'w') or die("Can't open php://output");
header("Content-Type:application/csv"); 
header("Content-Disposition:attachment;filename=pressurecsv.csv"); 
fputcsv($output, array('id','name','description'));
foreach($prod as $product) {
    fputcsv($output, $product);
}
fclose($output) or die("Can't close php://output");
EN

回答 6

Stack Overflow用户

发布于 2018-12-21 17:37:25

这是一个将数组导出为csv字符串的简单解决方案:

代码语言:javascript
复制
function array2csv($data, $delimiter = ',', $enclosure = '"', $escape_char = "\\")
{
    $f = fopen('php://memory', 'r+');
    foreach ($data as $item) {
        fputcsv($f, $item, $delimiter, $enclosure, $escape_char);
    }
    rewind($f);
    return stream_get_contents($f);
}

$list = array (
    array('aaa', 'bbb', 'ccc', 'dddd'),
    array('123', '456', '789'),
    array('"aaa"', '"bbb"')
);
var_dump(array2csv($list));

Reference

票数 20
EN

Stack Overflow用户

发布于 2012-10-28 18:51:24

尝试使用;

代码语言:javascript
复制
PHP_EOL

终止CSV输出中的每个新行。

我假设文本是定界的,但不是移动到下一行?

这是一个PHP常量。它将确定您所需的正确行尾。

例如,Windows使用"\r\n“。当我的输出没有突破到一个新的行时,我绞尽脑汁想了想这句话。

how to write unified new line in PHP?

票数 5
EN

Stack Overflow用户

发布于 2014-08-08 11:16:10

在我的例子中,我的数组是多维的,可能使用数组作为值。所以我创建了这个递归函数来完全分解数组:

代码语言:javascript
复制
function array2csv($array, &$title, &$data) {
    foreach($array as $key => $value) {      
        if(is_array($value)) {
            $title .= $key . ",";
            $data .= "" . ",";
            array2csv($value, $title, $data);
        } else {
            $title .= $key . ",";
            $data .= '"' . $value . '",';
        }
    }
}

由于我的数组的不同级别不适合平面CSV格式,所以我创建了一个带有子数组键的空白列,作为下一级数据的描述性“介绍”。示例输出:

代码语言:javascript
复制
agentid     fname           lname      empid    totals  sales   leads   dish    dishnet top200_plus top120  latino  base_packages
G-adriana   ADRIANA EUGENIA PALOMO PAIZ 886                0    19              0         0         0         0      0

您可以很容易地删除"intro“(描述性)列,但在我的示例中,每个子数组中都有重复的列标题,即inbound_leads,因此在下一节之前有一个分隔符/标题。删除:

代码语言:javascript
复制
$title .= $key . ",";
$data .= "" . ",";

在is_array()之后进一步压缩代码并删除多余的列。

因为我想要标题行和数据行,所以我将两个变量传递给函数,并在完成对函数的调用后,使用PHP_EOL终止这两个变量:

代码语言:javascript
复制
$title .= PHP_EOL;
$data .= PHP_EOL;

是的,我知道我留下了一个额外的逗号,但为了简洁,我没有在这里处理它。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13108157

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档