国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > PHP > 正文

php導(dǎo)出csv數(shù)據(jù)在瀏覽器中輸出提供下載或保存到文件的示例

2024-05-04 23:23:04
字體:
供稿:網(wǎng)友

1.在瀏覽器輸出提供下載

復(fù)制代碼 代碼如下:


/**
 * 導(dǎo)出數(shù)據(jù)到CSV文件
 * @param array $data  數(shù)據(jù)
 * @param array $title_arr 標(biāo)題
 * @param string $file_name CSV文件名
 */
function export_csv(&$data, $title_arr, $file_name = '') {
    ini_set("max_execution_time", "3600");

    $csv_data = '';

    /** 標(biāo)題 */
    $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] . "/"/r/n";
    }

    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] . "/"/r/n";
        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瀏覽器輸出中文名亂碼的bug
     $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.保存到文件

復(fù)制代碼 代碼如下:


function export_csv($data, $title_arr, $file_name = '') {


    $csv_data = '';


    /** 標(biāo)題 */
    $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] . "/"/r/n";
    }


    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] . "/"/r/n";
        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) ;
}

調(diào)用示例(保存到文件):

復(fù)制代碼 代碼如下:


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

$header = array(
                    '0' => '參數(shù)ID',
                    '1' => '參數(shù)名稱',
                    '2' => '統(tǒng)計次數(shù)',
                    '3' => '統(tǒng)計次數(shù)百分比',
                    '4' => '唯一用戶數(shù)',
                    '5' => '唯一用戶數(shù)百分比',
                    '6' => '人均次數(shù)'
            );
            $csvList = array(array("111", "title", "12", "100%", "23", "50%", "4")) ;
            export_csv($csvList, $header, $file_name) ;

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 万全县| 鄂托克旗| 恭城| 正定县| 武平县| 麦盖提县| 炉霍县| 汕头市| 舞阳县| 会昌县| 花垣县| 威宁| 曲周县| 长春市| 富蕴县| 康定县| 调兵山市| 石屏县| 蓬莱市| 剑川县| 汾西县| 芒康县| 舟山市| 九寨沟县| 太仆寺旗| 泗阳县| 通榆县| 兴业县| 隆林| 长寿区| 宁南县| 德兴市| 沅江市| 铜鼓县| 微博| 南漳县| 聂拉木县| 盘锦市| 德化县| 牡丹江市| 广水市|