您好,欢迎访问一九零五行业门户网

php利用open,fwrite实现导出多种格式的文件(代码)

本篇文章给大家带来的内容是关于php利用open,fwrite实现导出多种格式的文件(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
效果图
源码分析<?php/** * created by phpstorm. * user: jason0727 * date: 2018/8/9 * time: 14:48 */header("content-type: text/html;charset=utf-8");//定义文件名 $filename = "测试文件名_" . date('ymdhis');//文件名中间不能有空格//文件名转码,以防乱码 $filename = iconv('utf-8','gbk',$filename);///文件后缀 $ext = ".csv";//$ext = ".txt";//字段间的拼接符号// $dot = "|";$dot = ",";//打开文件句柄,记得赋权,否则报错 $fp = fopen("./files/" . $filename . $ext,"a") or die("unable to open file!");//是否需要列表名称,0=>不需要 1需要,默认为1 $is_need_headerlist = 1;//检测是否需要 headerlistif($is_need_headerlist == 1){ //定义列表名称 $headerlist = ['列表1','列表2','列表3']; //初始化写入文件的字符串 $headertxt = ""; //列表名称转码 foreach ($headerlist as $v){ $headertxt .= $v. $dot; } $headertxt = rtrim($headertxt,$dot)."\n"; //将列表名称写入文件句柄 fwrite($fp, $headertxt);}//初始化数组数据$data = [ ['id'=>'值1','name'=>'值2','hobby'=>'值3'], ['id'=>'值11','name'=>'值22','hobby'=>'值33'], ['id'=>'值111','name'=>'值222','hobby'=>'值333']];//循环写入数据//初始化数组的总数$count = count($data);//循环次数$limit = 0;foreach ($data as $v){ $limit++; $txt = $v['id'] .$dot . $v['name'] .$dot .$v['hobby']; if($count != $limit)//避免最后一次换行 $txt .= $dot .php_eol; fwrite($fp,$txt);}fclose($fp);
常见问题分析字符串中含有特殊的字符,在编码转换时,需要设置//ignore,否则会报错
$c = "测试•字符传换•五一快乐!";echo iconv('utf-8','gbk//ignore',$c);//测试字符传换五一快乐!echo iconv('utf-8','gbk',$c);//detected an illegal character in input string
数字字符串会出现格式化的情况,需要加如看不见的字符使其正常化,如:”\t”
转码问题,特殊情况,特殊处理,视情况而定
链接:https://pan.baidu.com/s/1sfb3lpoouyl-cvv4qovnka 密码:2o6b
相关推荐:
php导出csv格式的excel文件的实现代码
php如何实现模糊查询(图文代码)以上就是php利用open,fwrite实现导出多种格式的文件(代码)的详细内容。
其它类似信息

推荐信息