0

0

php如何读写csv文件_php读写csv文件函数流程【文件】

星夢妙者

星夢妙者

发布时间:2026-01-19 20:44:02

|

476人浏览过

|

来源于php中文网

原创

最稳php原生csv处理方案是fgetcsv和fputcsv,它们自动处理引号、转义、换行及rfc 4180兼容格式;需显式声明分隔符与引号,并手动跳过utf-8 bom以避免字段名异常。

php如何读写csv文件_php读写csv文件函数流程【文件】

fgetcsvfputcsv 读写 CSV 最稳

PHP 原生处理 CSV,别碰 file_get_contents + explode 这种写法——字段含逗号、换行或双引号时必然崩。直接上 fgetcsvfputcsv,它们专为 CSV 设计,自动处理转义和分隔符逻辑。

这两个函数底层调用 C 的 CSV 解析器,兼容 RFC 4180,能正确识别 "a,b",c,"d""e" 这类带引号、嵌套双引号、跨行字段的格式。

  • fgetcsv 每次读一行,返回数组,空行返回 false
  • fputcsv 自动加引号、转义双引号、按需换行,不手动拼字符串
  • 必须用 fopen 打开文件,不能传路径字符串给 fgetcsv

读 CSV 时注意 BOM 和编码问题

Windows 记事本保存的 CSV 常带 UTF-8 BOM(),fgetcsv 不会自动剥离,首列字段名可能变成 "name"(开头有不可见字符),导致 $row['name'] 取不到值。

解决方法是打开前跳过 BOM:

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

极品模板微商城订单系统
极品模板微商城订单系统

微商城订单管理系统是一款基于php+mysql开发的php订单管理系统,她的特点如下: 产品特色: 支持商品规格、订单短信提醒,订单提交限制,站外调用, 批量发货/导出,数据报表,物流轨迹、免签支付等。 1、高度开源:除核心授权文件外全部开源,二开方便。 2、分布式部署:支持分布式部署、支持数据库读写分离。 3、第三方存储:支持附件腾讯云、阿里云、七牛云存储

下载
function open_csv_for_read($path) {
    $fp = fopen($path, 'r');
    if ($fp === false) return false;
    // 检查并跳过 UTF-8 BOM
    $bom = fread($fp, 3);
    if ($bom !== "") fseek($fp, 0);
    return $fp;
}

$fp = open_csv_for_read('data.csv');
while (($row = fgetcsv($fp)) !== false) {
    // 正常处理 $row
}
  • 别用 mb_convert_encoding 盲转,BOM 是字节问题,不是编码问题
  • 如果源文件是 GBK/GB2312,必须用 stream_filter_append($fp, 'convert.iconv.GBK/UTF-8') 转码后再读
  • fgetcsv 默认按 UTF-8 解析,不处理其他编码

fputcsv 的 delimiter 和 enclosure 参数要显式传

默认用英文逗号 , 和双引号 ",但很多国产系统导出 CSV 用分号 ; 或制表符 ,不指定参数会导致 Excel 打开错列。

常见组合:

// 导出为 Excel 兼容的分号分隔(欧洲常用)
fputcsv($fp, $row, ';', '"', '\');

// 导出为 TSV(制表符分隔,无引号,适合纯 ASCII 数据)
fputcsv($fp, $row, "	", '', '');

// 中文字段含换行时,必须保留 enclosure,否则 Excel 会把换行当新行
fputcsv($fp, ['姓名', "张三
男"], ',', '"', '"');
  • 第三个参数 $delimiter:建议始终显式传,别依赖默认值
  • 第四个参数 $enclosure:双引号最安全;设为空字符串 '' 会禁用引号,但字段含 , 或换行就失效
  • 第五个参数 $escape:默认是双引号,即 "a""b" 表示 a"b;若设为反斜杠,需确保数据里没裸反斜杠

大文件读写必须用流式,别 file() 全加载

CSV 文件超 10MB 时,file('x.csv') 会把整个文件读进内存,PHP 内存溢出报 Fatal error: Allowed memory size exhausted

正确做法是边读边处理,用 fgetcsv 循环 + 显式释放变量:

$fp = fopen('big.csv', 'r');
if (!$fp) die('无法打开文件');

$headers = fgetcsv($fp); // 读标题行
while (($row = fgetcsv($fp)) !== false) {
    // 处理单行,例如插入数据库、校验、转换
    process_row($row, $headers);

    // 主动清空大变量,尤其 row 含长文本时
    unset($row);
}
fclose($fp);
  • 不要在循环里拼大数组,比如 $all[] = $row,内存照样爆
  • 写大文件同理:别先组装完整 CSV 字符串再 file_put_contents,而要用 fputcsv 逐行写
  • memory_get_usage(true) 在循环中抽样检查内存,早发现泄漏
实际项目里,最常被忽略的是 BOM 处理和分隔符显式声明——前者让字段键名莫名多出乱码,后者让 Excel 打开后全挤在一列。这两处不修,后面逻辑再严谨也没用。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

451

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

373

2023.10.25

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

718

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

219

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1561

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

649

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1168

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

1142

2024.04.29

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

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

精品课程

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

共137课时 | 13万人学习

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号