• 技术文章 >php教程 >php手册

    PHP导入和导出CSV文件实现程序

    2016-05-25 16:43:53原创921
    我们先准备mysql数据表,假设项目中有一张记录学生信息的表student,并有id,name,sex,age分别记录学生的姓名、性别、年龄等信息,代码如下:

    CREATE TABLE `student` (  
      `id` int(11) NOT NULL auto_increment,  
      `name` varchar(50) NOT NULL,  
      `sex` varchar(10) NOT NULL,  
      `age` smallint(3) NOT NULL default '0',  
      PRIMARY KEY  (`id`)  
    ) ENGINE=MyISAM  DEFAULT CHARSET=utf8;

    我们还需要一个html交互页面,放置导入表单和导出按钮,代码如下:

    请选择要导入的CSV文件:

    选择好本地csv文件后,点击导入,提交到do.php?action=import处理,而点击导出按钮则请求地址do.php?action=export进行数据导出处理.

    1.导入CSV

    do.php需要根据get过来的参数,分别处理导入和导出过程,php结构如下:

    导入CSV处理流程:校验csv文件合法性(本文忽略)->打开读入并解析csv文件中的字段->循环获取各字段值->批量添加到数据表中->完成,代码如下:

    注意php自带的fgetcsv函数可以轻松处理csv,使用该函数可以从文件指针中读入一行并解析CSV字段,下面的函数将csv文件字段解析并以数组的形式返回,代码如下:

    此外在导入到数据库中时,我们采用的是批量插入而不是一条条插入的,因此在构建SQL语句时,要稍作处理,见代码.

    2.导出CSV

    我们知道csv文件是由逗号分割符组成的纯文本文件,你可以用excel打开,效果跟xls表个一样.

    导出CSV处理流程:读取学生信息表->循环记录构建逗号分隔的字段信息->设置header信息->导出文件(下载)到本地,代码如下:

    要将数据导出到本地即下在,需要修改header信息,代码如下:

    注意导入和导出的过程中,因为我们使用的是统一UTF-8编码,遇到中文字符一定要记得转码,否则可能会出现中文乱码的情况.


    文章地址:

    转载随意^^请带上本文地址!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:实现程序 php导入 导出csv文件
    上一篇:PHP生成HTML纯静态网页程序代码 下一篇:PHP中获取URL完整路径程序代码
    Web大前端开发直播班

    相关文章推荐

    • PHP的CURLOPT_POSTFIELDS参数使用数组和字符串的区别• 几个php技巧• Linux下PHP连接MSSQLServer的办法• PHP的XML分析函数转 介绍这个PHP里的XML分析函数的文章可不太有哦。。看过这篇就应该清楚点了吧...• php header函数使用实例代码

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网