在php中生成csv文件的方法很是簡單,這裡我來介紹一下自己用到的一個實例,把數組直接轉換成csv文件輸出,有需要了解的朋友可參考。
例
代碼如下 復制代碼<?php
$data = array(
array( 'row_1_col_1', 'row_1_col_2', 'row_1_col_3' ),
array( 'row_2_col_1', 'row_2_col_2', 'row_2_col_3' ),
array( 'row_3_col_1', 'row_3_col_2', 'row_3_col_3' ),
);
$filename = "example";
header("Content-type: text/csv");
header("Content-Disposition: attachment; filename={$filename}.csv");
header("Pragma: no-cache");
header("Expires: 0");
outputCSV($data);
function outputCSV($data) {
$outputBuffer = fopen("php://output", 'w');
foreach($data as $val) {
foreach ($val as $key => $val2) {
$val[$key] = iconv('utf-8', 'gbk', $val2);// CSV的Excel支持GBK編碼,一定要轉換,否則亂碼
}
fputcsv($outputBuffer, $val);
}
fclose($outputBuffer);
}
?>
例2
看一個讀取csv文件的實例
讀取cvs,使用fgetcsv()文件指針中讀入一行並解析 CSV 字段
比如說我要讀取如下csv文件
代碼如下 復制代碼<?php
/** by www.bKjia.c0m */
$row = 1;
$handle = fopen("file.csv","r");
//fgetcsv() 解析讀入的行並找出 CSV格式的字段然後返回一個包含這些字段的數組。
while ($data = fgetcsv($handle, 1000, ",")) {
$num = count($data);
echo "<p> $num fields in line $row: <br>n";
$row++;
for ($c=0; $c < $num; $c++) {
//注意中文亂碼問題
$data[$c]=iconv("gbk", "utf-8//IGNORE",$data[$c]);
echo $data[$c] . "<br>n";
}
}
fclose($handle);
?>