-
- /**
- * データを CSV ファイルにエクスポートします
- * @param array $data data
- * @param array $title_arr title
- * @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 <$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 .= '"' 。 $row[$i] 。 '",';
- }
- $csv_data .= '"' 。 $row[$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,php导出csv数据,并保存文
-
-
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 < $nums - 1; ++$i) {
- $row[$i] = str_replace(""" , """", $row[$i]);
- $csv_data .= '"' 。 $row[$i] 。 '",';
- }
- $csv_data .= '"' 。 $row[$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) ;
- }
-
复制代码
附、php导出csvデータの调用例(文書に保存):
-
- $file_name="/var/www/tmp/test.csv" ;
- $header = array(
- '0' => 'パラメータID',
- '1' => 'パラメータ名',
- '2' => '统计次数',
- '3' => '唯一の用户数',
- '5' =>数百分比',
- '6' => '人均次数'
- );
- $csvList = array("111", "タイトル", "12", "100%", "23", "50% ", "4")) ;
- export_csv($csvList, $header, $file_name) ;
-
复制代
|