下面是将PHP数组转换成CSV格式文件输出的方法:
下面是将PHP数组转换成CSV格式文件输出的方法:
1. 使用fputcsv()函数实现
<?php
// 定义数据数组
$data = array(
array('name', 'age', 'email'),
array('Tom', 20, 'tom@example.com'),
array('Jack', 25, 'jack@example.com')
);
// 打开文件流
$fp = fopen('export.csv', 'w');
// 遍历数据,将每一行转换成CSV格式并写入文件流
foreach ($data as $row) {
fputcsv($fp, $row);
}
// 关闭文件流
fclose($fp);
注:代码中fopen()
函数用于打开文件流,第一个参数是生成的文件路径,第二个参数是文件打开模式,这里是'w'表示写入模式,会覆盖之前已有文件。还有fputcsv()
函数将一行数据数组转换成CSV格式,并写入到文件流中。
2. 使用CSVIterator类实现
<?php
// 定义数据数组
$data = array(
array('name', 'age', 'email'),
array('Tom', 20, 'tom@example.com'),
array('Jack', 25, 'jack@example.com')
);
// 将数据数组转换成字符串
$csv = '';
foreach ($data as $row) {
$csv .= implode(',', $row) . "\n";
}
// 将CSV格式字符串输出到浏览器,同时设置文件名为 export.csv
header('Content-Type: text/csv');
header('Content-Disposition: attachment; filename="export.csv"');
echo $csv;
注:代码中implode()
函数将一行数据数组转换成CSV格式字符串,分隔符为逗号。还有header()
函数设置输出的头信息,Content-Type为text/csv,表示输出的是CSV格式文件;Content-Disposition为attachment,表示将输出的文件作为附件下载;filename为下载时的文件名。
以上两种方式均可将PHP数组转换成CSV格式文件输出。第一种方式是将数据行依次写入文件流,适用于将数组数据写入CSV文件;第二种方式则是直接将数据数组转换成CSV格式字符串,输出到浏览器,适用于将数组数据导出到CSV文件的同时下载。
织梦狗教程
本文标题为:php将数组转换成csv格式文件输出的方法


基础教程推荐
猜你喜欢
- php ZipArchive实现多文件打包下载实例 2023-03-12
- 基于CI(CodeIgniter)框架实现购物车功能的方法 2022-10-12
- PHP实现基于状态的责任链审批模式详解 2023-01-19
- PHP实现抽奖功能实例代码 2023-04-20
- PHP5各个版本的新功能和新特性总结 2023-12-24
- PHP实现类似题库抽题效果 2022-11-11
- PHP的PDO大对象(LOBs) 2022-12-11
- laravel csrf验证总结 2023-05-20
- PHP zip压缩包操作类完整实例 2022-11-07
- thinkphp5框架扩展redis类方法示例 2023-01-14