0

0

php如何操作csv文件_php导入导出csv数据方法

冰火之心

冰火之心

发布时间:2025-08-30 17:00:02

|

750人浏览过

|

来源于php中文网

原创

答案是:php通过fgetcsv和fputcsv函数实现csv文件的导入导出,结合fopen、fclose进行文件操作,导入时逐行读取并关联表头,导出时设置正确http头并输出到浏览器,处理大文件需采用边读边处理、分批插入、cli模式或队列异步执行等策略以优化内存和执行时间。

php如何操作csv文件_php导入导出csv数据方法

PHP操作CSV文件,无论是导入还是导出数据,核心都围绕着PHP内置的

fgetcsv
fputcsv
这两个函数。它们提供了高效且灵活的方式来处理CSV的读写,是数据交换场景下的得力助手。理解并善用这两个函数,能让你轻松应对大部分CSV处理需求。

解决方案

说实话,处理CSV文件在PHP里,初看可能觉得有点麻烦,毕竟涉及文件IO,但实际上,PHP内置的那些文件操作函数,比如

fopen
fgetcsv
fputcsv
,用起来真是相当顺手。我个人觉得,只要理解了它们的工作原理,导入导出就不是什么难事了。

导入CSV数据: 通常,我们从用户那里拿到一个CSV文件,或者从某个地方下载下来。第一步总是打开它。

<?php
$filePath = 'data.csv'; // 假设这是你的CSV文件路径

if (!file_exists($filePath)) {
    die("错误:文件 {$filePath} 不存在。");
}

$file = fopen($filePath, 'r'); // 以只读模式打开文件

if ($file === false) {
    die("错误:无法打开文件 {$filePath}。请检查文件权限。");
}

$data = [];
$header = [];
$isHeader = true;

while (($row = fgetcsv($file, 1000, ',')) !== false) { // 每次读取一行,最大长度1000,逗号分隔
    if ($isHeader) {
        $header = $row;
        $isHeader = false;
        continue;
    }
    // 假设我们想把每一行数据关联到表头
    $rowData = [];
    foreach ($header as $index => $colName) {
        $rowData[$colName] = $row[$index] ?? null; // 防止列数不匹配
    }
    $data[] = $rowData;
}

fclose($file); // 关闭文件

echo "<pre class="brush:php;toolbar:false;">";
print_r($data);
echo "
"; // 实际应用中,你会把 $data 导入到数据库或者进行其他处理 ?>

这里有个小细节,

fgetcsv
的第二个参数是最大行长,虽然现代系统内存充足,但设一个合理的限制还是个好习惯,避免潜在的内存溢出,尤其是在处理非常大的文件时。第三个参数是分隔符,默认就是逗号,但你也可以改成制表符或其他。

导出CSV数据: 导出相对来说更直接一点,因为数据源通常是我们自己程序内部的数组或者数据库查询结果。关键在于设置正确的HTTP头,让浏览器知道这是一个要下载的文件。

<?php
// 假设这是我们要导出的数据
$exportData = [
    ['姓名', '年龄', '城市'],
    ['张三', '30', '北京'],
    ['李四', '25', '上海'],
    ['王五', '35', '广州']
];

$fileName = 'export_data_' . date('YmdHis') . '.csv';

header('Content-Type: text/csv');
header('Content-Disposition: attachment; filename="' . $fileName . '"');
header('Cache-Control: max-age=0'); // 避免浏览器缓存

$output = fopen('php://output', 'w'); // 直接输出到浏览器

if ($output === false) {
    die("错误:无法创建输出流。");
}

// 写入BOM头,解决Excel打开CSV中文乱码问题
fwrite($output, "\xEF\xBB\xBF"); 

foreach ($exportData as $row) {
    // 如果需要,可以在这里对数据进行编码转换,例如:
    // $encodedRow = array_map(function($item) {
    //     return mb_convert_encoding($item, 'GBK', 'UTF-8'); 
    // }, $row);
    fputcsv($output, $row); // 将每一行写入CSV
}

fclose($output);
exit(); // 确保不再输出其他内容
?>

这里我用了

php://output
,这真是个妙招,它允许你直接向HTTP响应体写入数据,而不需要先保存到服务器上的临时文件。这对于即时下载非常方便。另外,关于字符编码,这是一个常被忽略但又非常重要的问题。如果你的数据包含中文,强烈建议在
fputcsv
之前处理一下编码,比如写入UTF-8 BOM格式,这样Excel打开才不会乱码。不过,现在大部分现代软件都能很好地处理UTF-8,所以BOM头可能不是每次都必须,但了解它能帮你解决很多头疼的问题。

立即学习PHP免费学习笔记(深入)”;

ColorMagic
ColorMagic

AI调色板生成工具

下载

PHP处理超大CSV文件时,有哪些性能优化策略?

处理大型CSV文件,说实话,是个挑战,尤其是当文件大小达到几十上百兆,甚至几个G的时候。我遇到过几次因为文件太大导致服务器直接内存溢出或者执行超时的情况。所以,单纯的循环读取写入肯定是不够的,得有点策略。

首先,内存管理是重中之重。PHP的

memory_limit
默认值可能不够。但你不能无限调高,那不是解决问题的根本。
fgetcsv
本身就是逐行读取的,这很好,因为它不会一次性把整个文件加载到内存里。但如果你把每一行都存到一个大数组里(就像我上面导入示例那样),最终还是会撑爆内存。所以,正确的做法是边读边处理。例如,每读取1000行,就批量插入到数据库,然后清空当前批次的数据,而不是把所有数据都收集起来。

其次,执行时间

max_execution_time
是另一个瓶颈。对于导入操作,如果数据量巨大,可能需要几分钟甚至更久。这时候,你可以考虑:

  1. 分批处理:不是一次性处理完所有数据,而是通过前端上传分片,或者后端脚本分批执行,配合队列服务(如Redis、RabbitMQ)异步处理。
  2. CLI模式:如果是在命令行下运行PHP脚本(
    php your_script.php
    ),
    max_execution_time
    通常是无限的,这对于后台任务非常合适。

再者,**文件

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
rabbitmq和kafka有什么区别
rabbitmq和kafka有什么区别

rabbitmq和kafka的区别:1、语言与平台;2、消息传递模型;3、可靠性;4、性能与吞吐量;5、集群与负载均衡;6、消费模型;7、用途与场景;8、社区与生态系统;9、监控与管理;10、其他特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

207

2024.02.23

Java 消息队列与异步架构实战
Java 消息队列与异步架构实战

本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

48

2026.01.28

fclose函数的用法
fclose函数的用法

fclose是一个C语言和C++中的标准库函数,用于关闭一个已经打开的文件,是文件操作中非常重要的一个函数,用于将文件流与底层文件系统分离,释放相关的资源。更多关于fclose函数的相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

344

2023.11.30

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1006

2023.11.02

内存数据库有哪些
内存数据库有哪些

内存数据库有Redis、Memcached、Apache Ignite、VoltDB、TimesTen、H2 Database、Aerospike、Oracle TimesTen In-Memory Database、SAP HANA和ache Cassandra。更多关于内存数据库相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

671

2023.11.14

mongodb和redis哪个读取速度快
mongodb和redis哪个读取速度快

redis 的读取速度比 mongodb 更快。原因包括:1. redis 使用简单的键值存储,而 mongodb 存储 json 格式的数据,需要解析和反序列化。2. redis 使用哈希表快速查找数据,而 mongodb 使用 b-tree 索引。因此,redis 在需要高性能读取操作的应用程序中是一个更好的选择。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

501

2024.04.02

redis怎么做缓存服务器
redis怎么做缓存服务器

redis 作为缓存服务器的答案:redis 是一款开源、高性能、分布式的键值存储,可作为缓存服务器使用。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

413

2024.04.07

redis怎么解决数据一致性
redis怎么解决数据一致性

redis 提供了两种一致性模型,以维护副本数据一致性:强一致性 (sync) 确保写操作仅在复制到所有从节点后才完成;最终一致性 (async) 则在主节点上写操作后认为已完成,牺牲一致性换取性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

408

2024.04.07

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.4万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号