thinkphp5 csv格式导入导出(多数据处理)
关于csv文件格式的导出导入个人见解
先上代码:
<?php
namespace think; class Csv
{
/**
* 导出csv文件
* @param $list 数据源
* @param $title 数据列表
*/
public function put_csv($list,$title)
{
$file_name = "exam".time().".csv";//文件名
header('Content-Type: application/vnd.ms-excel');//设置内容类型为Excel
header('Content-Disposition: attachment;filename='.$file_name );//下载文件
header('Cache-Control: max-age=0');//表示当访问此网页后的0秒内再次访问不会去服务器
$file = fopen('php://output',"a");//打开文件或者 URL, php://output 是一个只写的数据流, 允许你以 print 和 echo 一样的方式 写入到输出缓冲区, a:写入方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建之。
$limit = ;
$calc = ;
foreach ($title as $v){
$tit[] = iconv('UTF-8', 'GB2312//IGNORE',$v);//转码
}
fputcsv($file,$tit);//将行格式化为 CSV 并写入一个打开的文件中。(标题)
foreach ($list as $v){
$calc++;
//-------核心!!!清空缓存,将缓存上的数据写入到文件--------
if($limit == $calc){
ob_flush();//将本来存在输出缓存中的内容取出来,调用ob_flush()之后缓冲区内容将被丢弃。
flush(); //待输出的内容立即发送。 具体查看:https://www.jb51.net/article/37822.htm
$calc = ;
}//-------核心--------
foreach($v as $t){
$tarr[] = iconv('UTF-8', 'GB2312//IGNORE',$t);
}
fputcsv($file,$tarr);//将行格式化为 CSV 并写入一个打开的文件中。(内容)
unset($tarr);//销毁指定的变量
}
unset($list);//销毁指定的变量
fclose($file);//关闭打开的文件
exit();
} // csv导入,此格式每次最多可以处理1000条数据(我觉得这个是不对的,他规定的是读取一行的最大长度)
//$filename 文件路径
public function input_csv($filename) {
$csv_file = $handle = fopen($filename,'r');//只读方式打开,将文件指针指向文件头]
$result_arr = array ();
$i = ;
//函数从文件指针中读入一行并解析 CSV 字段(一维数组)
while($data_line = fgetcsv($csv_file,)) {
//跳过第一行标题读取
if ($i == ) {
$GLOBALS ['csv_key_name_arr'] = $data_line;//将标题存储起来
$i ++;
continue;
}
//读取内容
foreach($GLOBALS['csv_key_name_arr'] as $csv_key_num => $csv_key_name ) {
$csv_key_name = iconv('gb2312','utf-8', $csv_key_name);//标题
if(empty($data_line[$csv_key_num])) {
$result_arr[$i][$csv_key_name] = '';
}else {
$value = iconv('gb2312','utf-8', $data_line[$csv_key_num]);//标题对应的内容
$result_arr[$i][$csv_key_name] = $value;
}
}
$i++;
}
fclose($handle); // 关闭指针
return $result_arr;
}
}
控制器的使用:
/**
* 大数据改 导出
*/
public function excelOut2()
{// 不限制脚本执行时间以确保导出完成
// set_time_limit(0); $data = db('receive') -> where($where) -> order('create_time desc')-> select();
$csv_title = array('订单编号','客户姓名','客户联电','身份证号码','收货地址','发展渠道编码','订单日期','总部商城号码','是否开户','备注','用户标识','开户号码','卡号','套餐','运单号','签收时间','签收状态','异常标记','入网时间','首充时间','首充金额','发展渠道','对应区分','发展人电话','兑换码','订单类型','发货人','发货日期','异常原因','异常转化情况','异常操作员工','异常操作时间','店铺','登记时间');
//csv导出
$csv = new Csv(); //实例化后才可以调用之前类文件定义好的方法
$csv->put_csv($data, $csv_title);
} /**
* 大数据改 导入
*/
public function excelIn3()
{
if (request() -> isPost())
{
// 获取表单上传文件
$file = request()->file('examfile');
if(empty($file)) {
$this->error('请选择上传文件');
}
$info = $file->move(ROOT_PATH.'public'.DS.'upload');
//获取文件(日期/文件),$info->getFilename();
$filename = ROOT_PATH.'public'.DS.'upload/'.$info->getSaveName();
// $handle = fopen($filename,'r');//只读方式打开,将文件指针指向文件头]
$csv = new Csv();
$result = $csv->input_csv($filename); // 解析csv
$len_result = count($result);//返回数目
if($len_result == ){
$this->error('此文件中没有数据!');
}
// fclose($handle); // 关闭指针
dump($result);
return ;
} return $this -> fetch();
}
有什么不对的欢迎提出建议。
thinkphp5 csv格式导入导出(多数据处理)的更多相关文章
- CSV文件导入导出MySQL
使用SQLyog 工具导入文件数据到MySQL: Excel文件导入导出: 需要驱动:Microsoft Office 2007驱动 导入需要注意的问题:1.Excel里数值列,默认导入会变成浮点型. ...
- Laravel 5使用Laravel Excel实现Excel/CSV文件导入导出的功能详解
1.简介 本文主要给大家介绍了关于Laravel 5用Laravel Excel实现Excel/CSV文件导入导出的相关内容,下面话不多说了,来一起看看详细的介绍吧. Laravel Excel 在 ...
- 完整代码:安卓小软件“CSV联系人导入导出工具”
完整代码:安卓小软件"CSV联系人导入导出工具" 开发了一个安卓小软件"CSV联系人导入导出工具",欢迎测试.本软件可以帮你快速备份和恢复联系人,不用担心号码遗 ...
- 开发了一个安卓小软件“CSV联系人导入导出工具”,欢迎测试
开发了一个安卓小软件"CSV联系人导入导出工具",欢迎测试.本软件可以帮你快速备份和恢复联系人,不用担心号码遗失,软件操作简单,使用方便. 下载地址: 百度网盘:https://p ...
- Laravel 5 中使用 Laravel Excel 实现 Excel/CSV 文件导入导出功能
1.简介 Laravel Excel 在 Laravel 5 中集成 PHPOffice 套件中的 PHPExcel,从而方便我们以优雅的.富有表现力的代码实现Excel/CSV文件的导入和导出. 该 ...
- MySql csv文件导入导出
一.导出到csv(本地导出) 通过mysql客户端shell连接到服务器,选择使用的数据库,输入sql代码: select * from test_info into outfile '/tmp/te ...
- 在 Laravel 5 中使用 Laravel Excel 实现 Excel/CSV 文件导入导出功能
1.简介 Laravel Excel 在 Laravel 5 中集成 PHPOffice 套件中的 PHPExcel ,从而方便我们以优雅的.富有表现力的代码实现Excel/CSV文件的导入和 导出 ...
- thinkphp5 使用PHPExcel 导入导出
首先下载PHPExcel类.网上很多,自行下载. 然后把文件放到vendor文件里面. 一般引用vendor里面的类或者插件用vendor(); 里面加载的就是vendor文件,然后想要加载哪个文件, ...
- [PL/SQL]使用PL/SQL实现ORACLE的Excel格式导入导出
注:教程所使用的PL/SQL Developer版本为10版本 1.oracle导出excel格式 第一步,在pl/sql窗口查询出你想要导出的数据. 第二步,选择你想导出的数据,然后右键" ...
随机推荐
- SubLime Text3 常用插件总结
近来开始恶补前端知识,在一定的技能基础上,逐渐开始进阶的学习和使用.因此在这里罗列下,SubLime Text3 常用插件: 1.Emmet 提高HTML & CSS3编写速度. 2.Them ...
- JavaScript 异步、栈、事件循环、任务队列
概览 我们经常会听到引擎和runtime,它们的区别是什么呢? 引擎:解释并编译代码,让它变成能交给机器运行的代码(runnable commands). runtime:就是运行环境,它提供一些对外 ...
- Spinner的简单实用
1.Spinner的功能 Spinner在Android中主要实现的是一个下拉列表,这个下拉列表相当于弹出一个弹出一个菜单供用户选择.即Spinner提供一个快速的方法从一组中选择一个值,默认状态下S ...
- vue 动态添加body背景图片
<script> export default { data () { return { bodyBgImage: 'url(' + require('../asse ...
- Java 网络编程相关知识
网络的一些基础知识 IP地址分类 IP地址根据网络ID的不同分为5种类型,A类地址.B类地址.C类地址.D类地址和E类地址.A类保留给政府机构,B类分配给中等规模的公司,C类分配给任何需要的人,D类用 ...
- Java基础知识3-类和对象(1)
面向过程和面向对象的区别 面向过程(结构化程序设计) 实际上是一个面向操作过程,首先设计一系列过程(算法)来求解问题(操作数据),然后再考虑存储数据的方式(组织数据).即程序=算法\+数据结构.对应典 ...
- Linux基础:Day06
网路安全介绍背景: 早起的互联网 -- 1980年代 ,我们需要共享数据,传输数据:所传输或者共享的数据均为明文: 随着互连网发展,安全称为了国家的一种战略资源: 我们做的,比如编程,运维 -- 手工 ...
- Pytest系列(13)- 重复执行用例插件之pytest-repeat的详细使用
如果你还想从头学起Pytest,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1690628.html 前言 平常在做功能测试的时候,经常 ...
- 微信小程序animation有趣的自定义动画
这几天在看代码时遇到了一些问题:关于微信小程序的animation自定义动画自己没有系统的学习过 做动画需要我们将一个复杂的动作过程,拆解为一步一步的小节过程 微信中已经为我们写好了端口我们只需要实例 ...
- Mac 系统root
没错,你没看错,就是root mac系统安装件的时候,你有没有遇到过这种情况 总之,就是安装不上软件,肿么办? 网上解觉办法是: 进入系统偏好设置,设置为允许任何人,可是进去后这样: 别着急,打开命令 ...