下面是将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去除deprecated的实例方法 2022-09-02
- Laravel 解决composer相关操作提示php相关异常的问题 2023-03-08
- php生成短网址/短链接原理和用法实例分析 2023-04-20
- PHP laravel使用自定义邮件类实现发送邮件 2023-07-03
- php+mysql开发的最简单在线题库(在线做题系统)完整案例 2023-01-04
- php如何获取当前日期和星期 2024-12-06
- PHP字符串函数系列之nl2br(),在字符串中的每个新行 (\n) 之前插入 HTML 换行符br 2024-03-28
- PHP采用get获取url汉字出现乱码的解决方法 2024-03-28
- Laravel修改验证提示信息为中文的示例 2023-03-08
- PHP基于反射机制实现自动依赖注入的方法详解 2022-10-02