Xinu

php生成csv文件下载/保存到本地
php生成csv文件,下载或者保存到本地。csv文件的本质就是以换行符和","来作区分的文件。下载csv函数<...
扫描右侧二维码阅读全文
31
2017/10

php生成csv文件下载/保存到本地

php生成csv文件,下载或者保存到本地。
csv文件的本质就是以换行符和","来作区分的文件。

下载csv函数

<?php
/**
 *生成csv文件并下载
 *
 * @param array $data 要生成的数据
 * @param array $title_arr 第一行的头信息
 * @param string $file_name 保存的文件名
 */
function createCsv($data, $title_arr, $file_name = '') {
    ini_set("max_execution_time", "3600");
    $csv_data = '';
    foreach ($title_arr as $k => $v) {
        $csv_data .= '"' . $v . '",';
    }
    $csv_data .= PHP_EOL;
    foreach ($data as $k => $row) {
        foreach ($row as $key => $v) {
            $v = str_replace("\"", "\"\"", $v);
            $csv_data .= '"' . $v . '",';
        }
        $csv_data .= PHP_EOL;
        unset($data[$k]);
    }
    $csv_data = function_exists('mb_convert_encoding') ? mb_convert_encoding($csv_data, "cp936", "UTF-8") : iconv("utf-8", "cp936//IGNORE", $csv_data);
    /*//TRANSLIT 和 //IGNORE,//TRANSLIT:使用相似字符替换不能转码的字符,//IGNORE:忽视不能转码的字符*/
    $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;
}

保存csv到本地

<?php
/**
 *生成csv文件并保存到本地
 *
 * @param array $data 要生成的数据
 * @param array $title_arr 第一行的头信息
 * @param string $file_name 保存的文件名
 */
function createCsv($data, $title_arr, $file_name = '') {
    ini_set("max_execution_time", "3600");
    $csv_data = '';
    foreach ($title_arr as $k => $v) {
        $csv_data .= '"' . $v . '",';
    }
    $csv_data .= PHP_EOL;
    foreach ($data as $k => $row) {
        foreach ($row as $key => $v) {
            $v = str_replace("\"", "\"\"", $v);
            $csv_data .= '"' . $v . '",';
        }
        $csv_data .= PHP_EOL;
        unset($data[$k]);
    }
    $csv_data = function_exists('mb_convert_encoding') ? mb_convert_encoding($csv_data, "cp936", "UTF-8") : iconv("utf-8", "cp936//IGNORE", $csv_data);
    /*//TRANSLIT 和 //IGNORE,//TRANSLIT:使用相似字符替换不能转码的字符,//IGNORE:忽视不能转码的字符*/
    $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 = dirname($file_name) . '/' . basename($file_name, '.csv') . '.csv';
    file_put_contents($file_name, $csv_data);
}
Last modification:October 31st, 2017 at 09:18 pm

Leave a Comment