PHP が CSV データをエクスポートしてブラウザに出力する_PHP チュートリアルのダウンロードまたはファイルへの保存の例を示します。

WBOY
リリース: 2016-07-13 10:31:52
オリジナル
888 人が閲覧しました

1. ブラウザ出力でダウンロードを提供します

コードをコピーします コードは次のとおりです:

/**
* データを CSV ファイルにエクスポートします
* @param array $data データ
* @param array $title_arr タイトル
* @param string $file_name CSV ファイル名
*/
function export_csv(&$data, $title_arr, $file_name = '') {
ini_set("max_execution_time") 、「3600」 );

$csv_data = '';

/**タイトル*/
$nums = count($title_arr);
for ($i = 0; $i $csv_data .= '"' . $title_arr[$i] . '",';
}

if ($nums > 0) {
$csv_data .= '"' . $title_arr[$nums - 1] . ""rn";
}

foreach ($data as $k => $row) {
for ($i = 0; $i < $nums - 1; ++$i) {
$row[$i] = str_replace("" ", """, $row[$i]);
$csv_data .= '"' . $nums - 1] . ""rn";
unset($data[$k]);
}

$csv_data = mb_convert_encoding($csv_data, "cp936", "UTF-8");

$file_name = empty($file_name) ? date('Y-m-d-H-i-s', time()) : $file_name;

if (strpos($_SERVER['HTTP_USER_AGENT'], "MSIE")) { // IE ブラウザで中国語名が文字化けして出力されるバグを解決

$file_name = urlencode($file_name);

$file_name = str_replace('+' , '%20', $file_name);
}

$file_name = $file_name . '.csv';

header("Content-type:text/csv;");

header("Content-Disposition:attachment;filename=" . $file_name);
header('Cache -Control:must-revalidate,post-check=0,pre-check=0');
header('Expires:0');
header('Pragma:public');
echo $csv_data;
}


2. ファイルに保存します

コードをコピーします コードは次のとおりです:
function export_csv($data, $title_arr, $file_name = '') {

$csv_data = '';


/**タイトル*/

$nums = count($title_arr);
for ($i = 0; $i < $nums - 1; ++$i) {
$csv_data .= '" ' . $title_arr[$i] . '",';
}

if ($nums > 0) {

$csv_data .= '"' . $title_arr[$nums - 1] . ""rn";
}

foreach ($data as $k => $row) {

for ($i = 0; $i $row[$i] = str_replace(" "", """", $row[$i]);
$csv_data .= '"' . [$nums - 1] . ""rn";
unset($data[$k]);
}


$file_name = empty($file_name) ? date('Y-m-d-H-i-s', time()) : $file_name;
file_put_contents($file_name, $csv_data) ;

}





呼び出し例

(ファイルに保存):

コードをコピー

コードは次のとおりです:

$file_name="/var/www/tmp/test.csv" ;

$header = array(
'3' = > ' '4' => 'ユニーク ユーザーの数',
'5' => '6' =>ユニーク ユーザー数の );
array("11 1", "タイトル", "12", "100%", "23", "50%", "4")) ;
export_csv($csvList, $ヘッダー、$file_name);






http://www.bkjia.com/PHPjc/760288.html

www.bkjia.com

本当

技術記事 1. ブラウザ出力には、次のようなダウンロード コピー コード コードが表示されます。 /** * データを CSV ファイルにエクスポート* @paramarray$data data* @paramarray$title_arr title* @paramstring$file_nameCSV ファイル名...
関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート