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

不言
不言 原创
2023-04-03 20:04:01 2004浏览

本篇文章给大家带来的内容是关于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);

常见问题分析

  1. 字符串中含有特殊的字符,在编码转换时,需要设置//IGNORE,否则会报错

$c = "测试•字符传换•五一快乐!";echo iconv('UTF-8','GBK//IGNORE',$c);//测试字符传换五一快乐!echo iconv('UTF-8','GBK',$c);//Detected an illegal character in input string
  1. 数字字符串会出现格式化的情况,需要加如看不见的字符使其正常化,如:”\t”

  2. 转码问题,特殊情况,特殊处理,视情况而定

链接:https://pan.baidu.com/s/1SFB3lPooUYl-cVv4QovNkA 密码:2o6b

相关推荐:

php导出csv格式的Excel文件的实现代码

PHP如何实现模糊查询(图文代码)

以上就是php利用open,fwrite实现导出多种格式的文件(代码)的详细内容,更多请关注php中文网其它相关文章!

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。