- A+

如果您需要将大量数据从外部文件导入到系统中,或希望将数据库中的记录导出为常用格式以便分享和备份,则可以通过PHP实现高效的数据导入导出功能。以下是完成该任务的具体步骤:
本文运行环境:MacBook Pro,macOS Sonoma
一、使用PHP处理CSV文件导入
CSV是一种轻量级且通用的文本格式,适合存储表格数据。通过PHP的文件读取函数与数据库操作结合,可以快速实现数据批量导入。
1、创建HTML表单允许用户上传CSV文件,设置enctype为multipart/form-data以支持文件提交。
立即学习“PHP免费学习笔记(深入)”;
2、在接收脚本中使用$_FILES['file']['tmp_name']获取临时文件路径,并用fopen()打开该文件资源。
3、使用fgetcsv()逐行读取数据,每行返回一个数组,对应CSV中的一条记录。
4、对每一行数据进行过滤和验证,例如检查必填字段是否为空,确保数据完整性。
5、将清洗后的数据通过PDO或MySQLi预处理语句插入数据库,防止SQL注入攻击。
二、利用PHPExcel库实现Excel文件导入
PHPExcel(现为PhpSpreadsheet)是一个强大的第三方库,支持读写多种电子表格格式,包括.xlsx和.xls,适用于复杂结构的数据导入。
1、通过Composer安装PhpSpreadsheet组件:composer require phpoffice/phpspreadsheet。
2、引入自动加载文件require_once 'vendor/autoload.php',初始化IO工厂读取上传的Excel文件。
3、使用SpreadsheetReader类加载文件并获取第一个工作表对象,调用getHighestRow()确定总行数。
4、遍历每一行数据,从第二行开始(假设第一行为标题),提取单元格值并映射到数据库字段。
5、执行批量插入操作,提升性能,避免逐条执行INSERT语句造成高延迟。
三、生成CSV格式导出文件
将数据库查询结果直接输出为可下载的CSV文件,是一种简单高效的导出方式,无需额外依赖库。
1、设置响应头信息,告知浏览器即将传输的是文件附件:header('Content-Type: text/csv') 和 header('Content-Disposition: attachment; filename="export.csv"')。

AI写作,AI写网文、AI写长篇小说、短篇小说

41
查看详情

2、打开输出流php://output作为文件句柄,使用fputcsv()将数组写入流中。
3、先写入列名行,字段顺序应与后续数据一致,便于识别。
4、执行SELECT查询获取待导出数据,循环结果集并将每条记录转换为数组形式写入CSV。
5、关闭文件句柄并终止脚本执行,防止额外输出破坏文件结构。
四、使用PhpSpreadsheet导出Excel文件
相较于CSV,Excel格式支持样式、多工作表和公式,更适合专业报表场景。
1、创建新的Spreadsheet实例,并获取活动工作表用于写入数据。
2、使用setCellValue()方法向指定单元格填充内容,如A1设置为“姓名”,B1为“邮箱”等标题。
3、从数据库获取数据后,逐行写入工作表,行索引从2开始递增。
4、配置HTTP响应头使浏览器触发下载动作,内容类型设为application/vnd.openxmlformats-officedocument.spreadsheetml.sheet。
5、通过Xlsx写入器将工作簿保存至php://output,实现即时下载。
五、优化大数据量导入导出性能
当处理上万条记录时,需采取分批处理与内存控制策略,防止超时或内存溢出。
1、导入时采用分块读取机制,每次处理1000行左右,处理完一批后清空变量释放内存。
2、使用事务包裹批量插入操作,提交前不生效,保证数据一致性。
3、导出时启用输出缓冲flush(),一边生成数据一边发送给客户端,降低服务器负载。
4、调整PHP配置参数,如max_execution_time提高至300秒以上,memory_limit设为-1(无限制)。
5、添加进度提示接口,前端可通过AJAX轮询导入状态,提升用户体验。




