thinkphp csv格式导入导出

封装成函数:

class Csv{/*** 导出csv文件*/public function export_csv($list, $title){$file_name = "export" . time() . ".csv"; // 文件名header('Content-Type: application/vnd.ms-excel'); // 设置内容类型为Excelheader('Content-Disposition: attachment;filename=' . $file_name); // 下载文件header('Cache-Control: max-age=0'); // 表示当访问此网页后的0秒内再次访问不会去服务器$file = fopen('php://output', "a");// 打开文件或者 URL,  php://output 是一个只写的数据流,  a:写入方式打开,将文件指针指向文件末尾。$limit = 1000;$num = 0;foreach ($title as $v) {$tle[] = iconv('UTF-8', 'GB2312//IGNORE', $v); // 转码}fputcsv($file, $tle);// 将行格式化为 CSV 并写入一个打开的文件中。(标题)foreach ($list as $v) {$num++;// 清空缓存,将缓存上的数据写入到文件if ($limit == $num) {ob_flush(); // 将本来存在输出缓存中的内容取出来,调用ob_flush()之后缓冲区内容将被丢弃。flush();    // 待输出的内容立即发送。$num = 0;}foreach ($v as $t) {$cArr[] = iconv('UTF-8', 'GB2312//IGNORE', $t);}fputcsv($file, $cArr); // 将行格式化为 CSV 并写入一个打开的文件中。(内容)unset($cArr); // 销毁指定的变量}unset($list);  // 销毁指定的变量fclose($file); // 关闭打开的文件exit();}// csv导入public function import_csv($dirName){$csv_file = $handle = fopen($dirName, 'r');//只读方式打开,将文件指针指向文件头]$result = array();$i = 0;// 读入一行并解析 CSV 字段(规定的是读取一行的最大长度)while ($data_line = fgetcsv($csv_file, 1000)) {// 跳过第一行标题读取if ($i == 0) {$GLOBALS ['key_name'] = $data_line; // 将标题存储起来$i++;continue;}// 读取内容foreach ($GLOBALS['key_name'] as $key_num => $key_name) {$key_name = iconv('gb2312', 'utf-8', $key_name); // 标题if (empty($data_line[$key_num])) {$result[$i][$key_name] = '';} else {// 标题对应的内容$value = iconv('gb2312', 'utf-8', $data_line[$key_num]); $result[$i][$key_name] = $value;}}$i++;}fclose($handle); // 关闭指针return $result;}
}

在控制器中的使用:

/*** 大数据改 导出*/
public function exportData(){
//        set_time_limit(0);$data = Db::name('table') -> order('create_time desc')-> select();$csv_title = array('编号','名称','手机号','邮件',);$csv = new Csv();  // 实例化后才可以调用之前类文件定义好的方法$csv->put_csv($data, $csv_title);
}/*** 大数据改 导入*/
public function importData(){if (request() -> isPost()){// 获取表单上传文件$file = request()->file('examfile');if(empty($file)) {$this->error('请选择上传文件');}$dirName = "public/uploads/csv";if(!file_exists($dirName)){mkdir(app()->getRootPath().$dirName,0777,true);}$info = $file->move($dirName);//获取文件(日期/文件),$info->getFilename();$filename = $dirName.'/'.$info->getSaveName();
//            $handle = fopen($filename,'r');// 只读方式打开,将文件指针指向文件头]$csv = new Csv();$result = $csv->input_csv($filename); // 解析csv$len_result = count($result);//返回数目if($len_result == 0){$this->error('此文件中没有数据!');}dump($result);
//            fclose($handle); // 关闭指针return;}return $this -> fetch();
}

后续看看是否有后续

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/91840.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SPSS列联表分析

前言: 本专栏参考教材为《SPSS22.0从入门到精通》,由于软件版本原因,部分内容有所改变,为适应软件版本的变化,特此创作此专栏便于大家学习。本专栏使用软件为:SPSS25.0 本专栏所有的数据文件可在个人主页—…

BUUCTF reverse wp 71 - 75

[NPUCTF2020]你好sao啊 int __cdecl main(int argc, const char **argv, const char **envp) {__int64 v3; // rax__int64 v4; // rdx__int64 v5; // raxsize_t v6; // rax__int64 v7; // rax__int64 v8; // rdx__int64 v9; // rax__int64 v11; // rdx__int64 v12; // raxchar …

【STM32】IAP升级01 bootloader实现以及APP配置(主要)

APP程序以及中断向量表的偏移设置 前言 通过之前的了解 之前的了解,我们知道实现IAP升级需要两个条件: 1.APP程序必须在 IAP 程序之后的某个偏移量为 x 的地址开始; 2.APP程序的中断向量表相应的移动,移动的偏移量为 x&#xff…

ROS2 中的轻量级、自动化、受控回放

一、说明 这篇文章描述了一种在 ROS2 中实现受控重播器的轻量级方法。用以测试中将现象重新播放一遍,以实现调参或故障定位的目的。所有源代码都可以在这里找到。该帖子也可在此处获得。 二、问题:不同步重播 任何曾经认真开发过 ROS2 的人都会知道这个问…

cloudCompare教程:一、可视化、点、线编辑

依据高度等准则(都在Scalar Fields中)渲染点云(首先要打开Tools -> Projection -> Export coordinate to SF) 在上述准则之外的,设置为不显示: 软件的显示设置(首先打开右边的彩色柱状图,点击左边属性…

TensorFlow 介绍 及其简单应用 附实例

TensorFlow是一种基于数据流编程的开源软件库,是人工智能领域中的重要工具,广泛应用于深度学习、自然语言处理等领域。 TensorFlow的基本概念包括: 张量(Tensor):存储和传递数据的多维数组,包括…

ECharts多个数据视图进行自适应大小的解决方案

项目场景: 在制作数据视图时经常会遇到多个数据视图的情况,在多个数据视图的情况下做自适应是比较麻烦的,这里就详细的分析一下该如何去制作,分享一下我的解决办法及思路。 定义 DOM 容器 这里需要注意一个地方,在定…

idea Springboot 校园助学贷款系统VS开发mysql数据库web结构java编程计算机网页源码maven项目

一、源码特点 springboot 校园助学贷款系统是一套完善的信息系统,结合springboot框架和bootstrap完成本系统,对理解JSP java编程开发语言有帮助系统采用springboot框架(MVC模式开发),系统 具有完整的源代码和数据库&…

2023.09.30使用golang1.18编译Hel10-Web/Databasetools的windows版

#Go 1.21新增的 log/slog 完美解决了以上问题,并且带来了很多其他很实用的特性。 本次编译不使用log/slog 包 su - echo $GOPATH ;echo $GOROOT; cd /tmp; busybox wget --no-check-certificate https://go.dev/dl/go1.18.linux-amd64.tar.gz;\ which tar&&am…

C++核心编程--继承篇

4.6、继承 继承是面向对象三大特征之一 有些类与类之间存在特殊的关系,例如下图中: ​ 我们发现,定义这些类的定义时,都拥有上一级的一些共性,还有一些自己的特性。那么我们遇到重复的东西时,就可以考虑使…

用go实现http服务端和请求端

一、概述 本文旨在学习记录下如何用go实现建立一个http服务器,同时构造一个专用格式的http客户端。 二、代码实现 2.1 构造http服务端 1、http服务处理流程 基于HTTP构建的服务标准模型包括两个端,客户端(Client)和服务端(Server)。HTTP 请求从客户端…

泰国数字加密平台Bitkub创始人到访上海和数集团

2023年9月21日,泰国数字加密货币交易平台Bitkub创始人兼首席执行官(CEO)Jirayut Srupsrisopa (Topp)先生到访上海和数集团总部。董事长唐毅先生热情会见了来宾,双方进行了友好深入的交流。 和数集团国际部经理晋松;苏州…

一文简要了解星闪技术优势点

文章目录 星闪推出的背景星闪的几个概念星闪技术的优势点传输速率高传输延迟极低连接数量多抗干扰能力强 小结 星闪推出的背景 提示:制裁之后星闪联盟诞生 由于美国对其进行了19年的制裁,华为被迫退出了国际蓝牙联盟,因此华为自主成立了星闪…

BUUCTF reverse wp 76 - 80

[CISCN2018]2ex 四处游走寻找关键代码 int __fastcall sub_400430(int a1, unsigned int a2, int a3) {unsigned int v3; // $v0int v4; // $v0int v5; // $v0int v6; // $v0unsigned int i; // [sp8h] [8h]unsigned int v9; // [sp8h] [8h]int v10; // [spCh] [Ch]v10 0;for…

在 Python 中列出虚拟环境

文章目录 在Python中列出虚拟环境使用lsvirtualenv命令使用Conda命令使用workon命令 总结 虚拟环境是一个独立的环境,我们可以在其中安装库、包、脚本和Python解释器。如果你的项目需要不同版本的库或Python解释器,你可以为每个项目创建单独的虚拟环境。…

2.索引操作

1. 创建索引 创建索引就等于创建数据库,ES使用put操作创建索引,我们创建一个students的索引,只需要发生put请求:http://127.0.0.1:9200/students 2. 查看索引 2.1 查看所有索引: 使用http://127.0.0.1:9200/_cat/ind…

Firefox 开发团队对 Vue 3 进行优化效果显著

Mozilla 官方博客近日发表文章《Faster Vue.js Execution in Firefox》,介绍了 Firefox 开发团队对 Vue 3 进行的优化。 文章写道,在使用 Speedometer 3 对 Firefox 进行基准测试时,他们发现 Vue.js test 的测试结果从 Vue 2 升级到 Vue 3 后…

ElasticSearch 同步数据变少了

一、前言 这几天对接ES遇到几个坑,我们将一张库存表同步到ES发现Docs Count和我们表中的数据对不上,需要加上Docs deleted才对得上,也不知道批量写入数据为什么有些数据就会成 Docs deleted。 二、ID和版本号 ES中每一个Document都有一个_…

大规模语言模型--中文 LLaMA和Alpaca

中文LLaMA 尽管 LLaMA 和 Alpaca 在 NLP 领域取得了重大进展, 它们在处理中文语言任务时, 仍存在一些局限性。这 些原始模型在字典中仅包含数百个中文 tokens (可以理解为单词),导致编码和解码中文文本的效率受到了很大 影响。 之前已经对…

数据结构--队列

一、队列是什么 队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,队列是一种操作受限制的线性表。进行插入操作的端称为队尾&…