PHP读取CSV大文件导入数据库的实例


Posted in PHP onJuly 24, 2017

PHP如何对CSV大文件进行读取并导入数据库?

对于数百万条数据量的CSV文件,文件大小可能达到数百M,如果简单读取的话很可能出现超时或者卡死的现象。

为了成功将CSV文件里的数据导入数据库,分批处理是非常必要的。

下面这个函数是读取CSV文件中指定的某几行数据:

/**
 * csv_get_lines 读取CSV文件中的某几行数据
 * @param $csvfile csv文件路径
 * @param $lines 读取行数
 * @param $offset 起始行数
 * @return array
 * */
function csv_get_lines($csvfile, $lines, $offset = 0) {
 if(!$fp = fopen($csvfile, 'r')) {
 	return false;
 }
 $i = $j = 0;
	while (false !== ($line = fgets($fp))) {
		if($i++ < $offset) {
			continue; 
		}
		break;
	}
	$data = array();
	while(($j++ < $lines) && !feof($fp)) {
		$data[] = fgetcsv($fp);
	}
	fclose($fp);
 return $data;
}

调用方法:

$data = csv_get_lines('path/bigfile.csv', 10, 2000000);

print_r($data);

函数主要采用行定位的思路,通过跳过起始行数来实现文件指针定位。

至于数据如何入库本文不再详细讲述。

上述函数对500M以内的文件进行过测试,运行通畅,对于更大的文件未做测试,请斟酌使用或加以改进。

这篇PHP读取CSV大文件导入数据库的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
PHP 获取远程文件内容的函数代码
Mar 24 PHP
PHP is_dir() 判断给定文件名是否是一个目录
May 10 PHP
解析Ubuntu下crontab命令的用法
Jun 24 PHP
php 无限级分类,超级简单的无限级分类,支持输出树状图
Jun 29 PHP
PHP读取PPT文件的方法
Dec 10 PHP
php实现爬取和分析知乎用户数据
Jan 26 PHP
PHP微信刮刮卡 附微信接口
Jul 22 PHP
PHP微信API接口类
Aug 22 PHP
PHP截取发动短信内容的方法
Jul 04 PHP
PHP注释语法规范与命名规范详解篇
Jan 21 PHP
PHP的RSA加密解密方法以及开发接口使用
Feb 11 PHP
PHP设计模式之适配器模式定义与用法详解
Apr 03 PHP
Yii2.0多文件上传实例说明
Jul 24 #PHP
thinkphp分页集成实例
Jul 24 #PHP
PHP 实现页面静态化的几种方法
Jul 23 #PHP
PHP魔术方法之__call与__callStatic使用方法
Jul 23 #PHP
php魔法函数与魔法常量使用介绍
Jul 23 #PHP
php curl上传、下载、https登陆实现代码
Jul 23 #PHP
php类自动装载、链式操作、魔术方法实现代码
Jul 23 #PHP
You might like
珊瑚虫IP库浅析
2007/02/15 PHP
PHP教程 基本语法
2009/10/23 PHP
百度ping方法使用示例 自动ping百度
2014/01/26 PHP
ThinkPHP3.1新特性之多数据库操作更加完善
2014/06/19 PHP
PHP+AJAX 投票器功能
2017/11/11 PHP
通过源码解析Laravel的依赖注入
2018/01/22 PHP
PHP基于DateTime类解决Unix时间戳与日期互转问题【针对1970年前及2038年后时间戳】
2018/06/13 PHP
jquery实现微博文字输入框 输入时显示输入字数 效果实现
2013/07/12 Javascript
JavaSacript中charCodeAt()方法的使用详解
2015/06/05 Javascript
jquery中ready()函数执行的时机和window的load事件比较
2015/06/22 Javascript
JavaScript实现广告的关闭与显示效果实例
2015/07/02 Javascript
JS+CSS实现的日本门户网站经典选项卡导航效果
2015/09/27 Javascript
js日期插件dateHelp获取本月、三个月、今年的日期
2016/03/07 Javascript
Bootstrap CSS布局之列表
2016/12/15 Javascript
详解axios在vue中的简单配置与使用
2017/05/10 Javascript
如何正确理解vue中的key详解
2019/11/02 Javascript
OpenLayers3加载常用控件使用方法详解
2020/09/25 Javascript
在Python的gevent框架下执行异步的Solr查询的教程
2015/04/16 Python
详解Python中find()方法的使用
2015/05/18 Python
编写Python脚本把sqlAlchemy对象转换成dict的教程
2015/05/29 Python
python pandas 对series和dataframe的重置索引reindex方法
2018/06/07 Python
Python 比较文本相似性的方法(difflib,Levenshtein)
2018/10/15 Python
12个步骤教你理解Python装饰器
2019/07/01 Python
python的pygal模块绘制反正切函数图像方法
2019/07/16 Python
利用Pandas和Numpy按时间戳将数据以Groupby方式分组
2019/07/22 Python
python 实现多线程下载视频的代码
2019/11/15 Python
Pytorch GPU显存充足却显示out of memory的解决方式
2020/01/13 Python
Python通过yagmail实现发送邮件代码解析
2020/10/27 Python
详解css3 object-fit属性
2018/07/27 HTML / CSS
英国第一独立滑雪板商店:The Snowboard Asylum
2020/01/16 全球购物
UNIX操作系统结构由哪几部分组成
2016/02/17 面试题
电大学习个人自我评价范文
2013/10/04 职场文书
煤矿安全生产标语
2014/06/06 职场文书
2014领导班子四风问题对照检查材料思想汇报
2014/09/21 职场文书
党组织结对共建协议书
2016/03/23 职场文书
Django 如何实现文件上传下载
2021/04/08 Python