首頁 >後端開發 >php教程 >php利用open,fwrite實作匯出多種格式的檔案(程式碼)

php利用open,fwrite實作匯出多種格式的檔案(程式碼)

不言
不言原創
2018-08-18 17:40:272760瀏覽

這篇文章帶給大家的內容是關於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(&#39;YmdHis&#39;);//文件名中间不能有空格//文件名转码,以防乱码
 $fileName = iconv(&#39;UTF-8&#39;,&#39;GBK&#39;,$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 = [&#39;列表1&#39;,&#39;列表2&#39;,&#39;列表3&#39;];    //初始化写入文件的字符串
    $headerTxt = "";    //列表名称转码
    foreach ($headerList as $v){        
    $headerTxt .= $v. $dot;
    }    
    $headerTxt = rtrim($headerTxt,$dot)."\n";    //将列表名称写入文件句柄
    fwrite($fp, $headerTxt);
}//初始化数组数据$data = [
    [&#39;id&#39;=>&#39;值1&#39;,&#39;name&#39;=>&#39;值2&#39;,&#39;hobby&#39;=>&#39;值3&#39;],
    [&#39;id&#39;=>&#39;值11&#39;,&#39;name&#39;=>&#39;值22&#39;,&#39;hobby&#39;=>&#39;值33&#39;],
    [&#39;id&#39;=>&#39;值111&#39;,&#39;name&#39;=>&#39;值222&#39;,&#39;hobby&#39;=>&#39;值333&#39;]
];
//循环写入数据//初始化数组的总数
$count = count($data);//循环次数
$limit = 0;foreach ($data as $v){    
$limit++;    
$txt = $v[&#39;id&#39;] .$dot . $v[&#39;name&#39;] .$dot .$v[&#39;hobby&#39;];    
if($count != $limit)//避免最后一次换行
        $txt .= $dot .PHP_EOL;
    fwrite($fp,$txt);
}
fclose($fp);

常見問題分析

  1. 字串中含有特殊的字符,在編碼轉換時,需要設定//IGNORE,否則會報錯

  2. ##
    $c = "测试•字符传换•五一快乐!";echo iconv(&#39;UTF-8&#39;,&#39;GBK//IGNORE&#39;,$c);//测试字符传换五一快乐!echo iconv(&#39;UTF-8&#39;,&#39;GBK&#39;,$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