PHP 数组与CSV文件互转
项目说明
数组导出CSV,ZIP文件,CSV,ZIP文件还原数组(阵列导出文件,文件恢复阵列)适用于导入导出会员,商品信息
所有配置项ExecData
中配置
注意:读取中文文件名文件,数据时需要注意本地区域设置
写入文件数据是UTF-8,设置 FetchFile 类中 fetchFile() 函数中 setlocale(LC_ALL, 'US')
才可读取到数据;
测试平台为WIN,其他平台未测试;
如果不能读取数据,请根据相应地区字符编码设置
数据转码编码说明
- PHP文件编码与网页编码
$this->config[ 'webChar']
一致都为UTF-8 - 写入文件时,传入的文件名(参数)编码是UTF-8(PHP文件编码),将文件名转换为
$this->config[ 'fileNameChar']
(GBK),否则中文文件名乱码,数据数据编码为传入时原数据编码UTF -8(PHP文件编码) - 读取文件时,判断文件是否存在,传入的文件名(参数)编码为UTF-8(PHP文件编码),中文文件名必须转为
$this->config['fileNameChar']
(GBK)才能判断 - 读取文件数据时,原数据如果有中文,会出现乱码,需要重新设置输入输出编码为UTF-8(PHP文件编码,网页编码)
- 读取压缩文件中某个指定的文件时(按照文件名读取时),传入的参数为UTF-8(PHP文件编码),写入压缩包时文件名为
$this->config[ 'fileNameChar']
(GBK);读取压缩包文件(根据传入的文件名读取)数据时,文件名编码必须一致,否则读取不到数据
文件说明
| --- datafile /导出文件存放位置必须有创建,写入,读取权限
| ---日志/读取文件是错误日志存放位置必须有创建,写入权限
| --- src /
| --- demo.php示例文件
| --- ExceData.php执行读写操作调用类文件
| --- FetchFile.php读取文件操作类
| --- Pub.php读写操作基类
| --- WriteFile .php数组写入文件(下载)类
| --- test /示例图片
数组数据导出(下载)CSV / ZIP文件
传入数组,如果限制每个文件的数据条数小于数组长度,自动生成压缩文件;
如果限制每个文件的数据条数大于数组长度,根据参数设置是否压缩文件;
调用示例:$exec=new ExecData(); $exec->writeData($two);
;
共5个参数,第一个参数必填,其他参数可选
* @param $ data数组数据
* @param $ tit csv文件title,Array或者'aa,bb'字符串类型,建议数组长度与数据每个二维数据长度一致
* @param $ limit每个文件数据条数
* @param $ filename文件名,不加后缀,例如`aa`,生成的文件是`aa.csv / aa.zip`;默认文件名`WriteFile-> defaultFileName()`函数定义
* @param $ compr单个文件是否压缩,默认false不压缩
CSV / ZIP文件还原/导入数组数据
读取CSV文件,返回数组;
如果读取压缩包中所有文件如果没有错误,获取数组后会自动删除源文件;如果有错误,会输出提示信息,可以通过ExecData
类文件中的fetchData
函数配置项中的logOut
设置是否输出读取文件压缩包,压缩包有多少个有内容的文件,就返回几个数组
如果读取整个文件并且没有错误,是否删除源文件可以通过配置FetchFile
类中$this->config["isDelFile"]=false
设置,默认不删除,值为false
修改读取文件时错误日志存放位置配置:ExceData
文件fetchData()
函数中$f_config['logFile']
设置自分类中翻译定义即可
调用示例:$exec=new ExecData(); $exec->fetchData("compress2.csv");
共4个参数,第一个参数必填,其他参数可选
* @param $ filename要读取的文件名
* @param bool是否返回文件中的tit,默认false不返回;
* @param bool是否将csv文件中的tit做为数组的key,默认false返回索引数组
* @param int / string
* int读取第几个文件的数据,默认0读取所有文件,如果压缩文件中只有一个文件忽略此参数
*如果$ index = 1,读取第一个文件;
* string要读取的文件名如果嵌套文件请添加文件夹路径例如aa / aa.csv,$ fileway参数必须为false
项目地址:https://github.com/xue-y/arrcsv
packagist:https://packagist.org/packages/xue-y/arrcsv
PHP 数组与CSV文件互转的更多相关文章
- python:将numpy数组写入csv文件
import numpy as np np.savetxt('E:\\forpython\\featvector.csv',data_to_save,delimiter=',')
- java读取目录下所有csv文件数据,存入三维数组并返回
package dwzx.com.get; import java.io.BufferedReader; import java.io.File; import java.io.FileReader; ...
- php上传excle文件,csv文件解析为二维数组
解析上传的CSV文件不是什么难事,直接读取转成你想要的数组样子就OK了. public function putStoreStockIn ($filePath = '') { $file = fope ...
- C++ 把数组数据存入 CSV 文件,以及读取 CSV 文件的数据
1. CSV-百度百科 2. 代码 #pragma once //Microsoft Visual Studio 2015 Enterprise #include<iostream> #i ...
- 将数组,矩阵存入csv文件中
我们在做各种模型训练时,往往会先将数据处理成矩阵,然后交给建模的人去训练.这时通常数据清洗者提交的是保存了矩阵的文件,一般为TXT或csv,接下来主要讲解我在实现这个过程中遇到的一些问题. impor ...
- PHP导出数据到CSV文件函数 csv_export()
后台往往需要导出各种数据到 Excel文档中.通常我们是导出 .csv文件格式,PHP导出函数参考代码如下: /** * 导出数据到CSV文件 * * @param array $data 二维数组( ...
- php解析.csv文件
public function actionImport() { //post请求过来的 $fileName = $_FILES['file']['name']; $fileTmpName = $_F ...
- CSV文件的读取 导出
CSV文件是 逗号分隔值文件 内容基本是这么存的... 姓名,年龄,性别/r/n王有才,,男/r/n王二妞,,女 一行值内用逗号 , 分开 行与行之间用 /r/n 分隔 说白了,他其实是一个字符 ...
- 使用PHP导入和导出CSV文件
我们先准备mysql数据表,假设项目中有一张记录学生信息的表student,并有id,name,sex,age分别记录学生的姓名.性别.年龄等信息. CREATE TABLE `student` ( ...
随机推荐
- SliceBox
SliceBox相当于一个轮播图插件,只不过是3D的. 先来查看它能实现的效果: 官网:http://tympanus.net/codrops/2011/09/05/slicebox-3d-image ...
- .NET开源MSSQL、Redis监控产品Opserver之MSSQL配置
MSSQL的配置比较简单,主要包括三部分: 默认配置(defaultConnectionString).集群配置(clusters).单实例配置(instances) defaultConnectio ...
- 代码审查清单 Code Review
代码审查清单 常规项 代码能够工作么?它有没有实现预期的功能,逻辑是否正确等. 所有的代码是否简单易懂? 代码符合你所遵循的编程规范么?这通常包括大括号的位置,变量名和函数名,行的长度,缩进,格式和注 ...
- ACM 媛在努力 华山论剑
媛在努力 描述在多媒体数据处理中,数据压缩算法尤为重要.小媛上完课后就想自己发明一个数据压缩算法.她想呀想,终于想到一个方法.在多媒体数据中有很多数据都是重复的,所以她想把连续相同的数据用数据出现的次 ...
- 迟到的成果——Qt 小学生出题神器设计
Github传送门 Part 1.成果展示及感想 原先一直有个疑惑的问题困扰着对Qt一无所知的我:如何才能使得C++代码在Qt上运行.然而这种困惑在进一步对Qt的了解过程中都得到了慢慢的解决,逐渐有一 ...
- Elasticsearch 5.6.5 安装head插件
head安装包,下载地址:https://github.com/mobz/elasticsearch-head/archive/master.zip head 插件不能放在elasticsearch- ...
- struts2下面如何同时使用servlet,就是如何实现struts与servlet共存
转载 原文链接:https://blog.csdn.net/u013358115/article/details/20706607 问题 项目要求struts2和servlet能够共存,就是strut ...
- zookeeper DataTree内存模型介绍及对Znode的四大特性介绍和Stat结构分析
一. zookeeper的内存模型 1. zookeeper是一个由 znode节点组成的一个树形结构 2. 每个znode都可以做成一个subject... 3. 客户端可以监控每一个节 ...
- JAVA篇之环境安装(Windows)
一.JAVA 安装两个重要概念 1.JRE::英文Java Development Kit ,记住英文,深入理解就去看相关文章. 2.JDK:英文 Java Runtime Environment,记 ...
- 工作中的Buff加成-结构化思考力:第一章:认识结构化思维及其作用
一:引言 为了更好的说明结构思考力,我们先来做几个小测试. PS:如果你能做到,请留言,因为我要和你交好友,因为你是人才啊,可以挖一挖,挖到我的公司中. 第一个测试:请在三秒内记住下列数字.数字顺序不 ...