PHP 讀取/導出 CSV文件


工作中經常會有遇到導入/導出的需求,下面是常用的方法。
讀取CSV文件,可以分頁讀取,設置讀取行數,起始行數即可。
導出CSV文件,用兩種方法進行實現。

 1 /**
 2  * 讀取CSV文件
 3  * @param string $csv_file csv文件路徑
 4  * @param int $lines       讀取行數
 5  * @param int $offset      起始行數
 6  * @return array|bool
 7  */
 8 public function read_csv_lines($csv_file = '', $lines = 0, $offset = 0)
 9 {
10     if (!$fp = fopen($csv_file, 'r')) {
11         return false;
12     }
13     $i = $j = 0;
14     while (false !== ($line = fgets($fp))) {
15         if ($i++ < $offset) {
16             continue;
17         }
18         break;
19     }
20     $data = array();
21     while (($j++ < $lines) && !feof($fp)) {
22         $data[] = fgetcsv($fp);
23     }
24     fclose($fp);
25     return $data;
26 }
27 /**
28  * 導出CSV文件
29  * @param array $data        數據
30  * @param array $header_data 首行數據
31  * @param string $file_name  文件名稱
32  * @return string
33  */
34 public function export_csv_1($data = [], $header_data = [], $file_name = '')
35 {
36     header('Content-Type: application/octet-stream');
37     header('Content-Disposition: attachment; filename=' . $file_name);
38     if (!empty($header_data)) {
39         echo iconv('utf-8','gbk//TRANSLIT','"'.implode('","',$header_data).'"'."\n");
40     }
41     foreach ($data as $key => $value) {
42         $output = array();
43         $output[] = $value['id'];
44         $output[] = $value['name'];
45         echo iconv('utf-8','gbk//TRANSLIT','"'.implode('","', $output)."\"\n");
46     }
47 }
48 /**
49  * 導出CSV文件
50  * @param array $data        數據
51  * @param array $header_data 首行數據
52  * @param string $file_name  文件名稱
53  * @return string
54  */
55 public function export_csv_2($data = [], $header_data = [], $file_name = '')
56 {
57     header('Content-Type: application/vnd.ms-excel');
58     header('Content-Disposition: attachment;filename='.$file_name);
59     header('Cache-Control: max-age=0');
60     $fp = fopen('php://output', 'a');
61     if (!empty($header_data)) {
62         foreach ($header_data as $key => $value) {
63             $header_data[$key] = iconv('utf-8', 'gbk', $value);
64         }
65         fputcsv($fp, $header_data);
66     }
67     $num = 0;
68     //每隔$limit行,刷新一下輸出buffer,不要太大,也不要太小
69     $limit = 100000;
70     //逐行取出數據,不浪費內存
71     $count = count($data);
72     if ($count > 0) {
73         for ($i = 0; $i < $count; $i++) {
74             $num++;
75             //刷新一下輸出buffer,防止由於數據過多造成問題
76             if ($limit == $num) {
77                 ob_flush();
78                 flush();
79                 $num = 0;
80             }
81             $row = $data[$i];
82             foreach ($row as $key => $value) {
83                 $row[$key] = iconv('utf-8', 'gbk', $value);
84             }
85             fputcsv($fp, $row);
86         }
87     }
88     fclose($fp);
89 }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM