欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

php导出csv数据在浏览器中输出提供下载或保存到文件的示例

程序员文章站 2023-11-21 13:43:16
1.在浏览器输出提供下载 复制代码 代码如下:/** * 导出数据到csv文件 * @param array $data ...

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 < $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.保存到文件

复制代码 代码如下:

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] . "\"\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) ;
}

调用示例(保存到文件):

复制代码 代码如下:

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

$header = array(
                    '0' => '参数id',
                    '1' => '参数名称',
                    '2' => '统计次数',
                    '3' => '统计次数百分比',
                    '4' => '唯一用户数',
                    '5' => '唯一用户数百分比',
                    '6' => '人均次数'
            );
            $csvlist = array(array("111", "title", "12", "100%", "23", "50%", "4")) ;
            export_csv($csvlist, $header, $file_name) ;