欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

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

程序员文章站 2022-03-17 10:58:20
...
本篇文章给大家带来的内容是关于php利用open,fwrite实现导出多种格式的文件(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

效果图

php利用open,fwrite实现导出多种格式的文件(代码)
php利用open,fwrite实现导出多种格式的文件(代码)
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);

常见问题分析

  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 导出