时间:2021-07-01 10:21:17 帮助过:2人阅读
<?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实现导出多种格式的文件(代码)的详细内容,更多请关注Gxl网其它相关文章!