-
- $list = array (
- 'aaa,bbb,ccc,dddd',
- '123,456,789',
- '"aaa","bbb"'
- );
- $fp = fopen( 'file.csv', 'w');
- foreach ($list as $line) {
- fputcsv($fp, Split(',', $line));
- fclose($fp);
- }
コードをコピーします しかし、PHP の以前のバージョンにはそのような組み込み関数はありません。カスタム関数を自分で実装できます。
- function fputcsv4($fh, $arr){
- $csv = "";
- while (list($key, $val) = each($arr))
- {
- $ val = str_replace('"', '""', $val);
- $csv .= '"'.$val.'",';
- }
- $csv = substr($csv, 0, -1) ;
- $csv .= "n";
- if (!@fwrite($fh, $csv))
- return FALSE;
- }
コードをコピーこのようにして、データベースから読み取られた配列は次のようになります。 csvファイルに変換して書き込まれます
コード:
- $users = $this->mdMemUsers->findBysql($sql);
- $i = 0;
- foreach($users as $vo){
- $content[$ i] = implode(',',$vo);
- $i++;
- }
- $fp = fopen('users.csv', 'w');
- foreach ($content as $line) {
- fputcsv4($ fp, Split(',', $line));
- }
コードをコピー
|