当前位置:  编程技术>php

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

    来源: 互联网  发布时间:2014-08-26

    本文导语:  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"...

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

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

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

代码如下:

$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) ;


    
 
 

您可能感兴趣的文章:

  • PHP导出excel php使用phpexcel导出excel文件
  • php导出csv时身份证号禁止科学计数
  • PHP导出CSV表格文件的方法
  • php导出(生成)CSV文件的小例子
  • php导出word文档与excel表格文件
  • php导出csv文件函数(增强版)
  • PHP导出excel时数字变为科学计数的解决方法
  • php导出word文档与excel电子表格的简单示例代码
  • PHP导入与导出Excel文件的方法
  • php读取csv、写入csv与导出csv文件
  • php导出excel单元格自动换行怎么实现?
  • php导出csv文件乱码问题的解决实例
  • php导出CSV文件的简单示例
  • php导出csv格式文件的例子
  • php生成(导出)csv文件的函数示例
  • php导出xls文件的方法
  • PHP实现把MySQL数据库导出为.sql文件实例(仿PHPMyadmin导出功能)
  • php导出csv文件打开乱码的解决方法
  • php导出数据为csv文件(入门实例)
  • php把数据表导出为Excel表的最简单、最快的方法(不用插件)
  • php通过socket_bind()设置IP地址代码示例
  • php循环创建目录示例分享(php创建多级目录)
  • PHP获取php,mysql,apche的版本信息示例代码
  • php定义数组和使用示例(php数组的定义方法)
  • php输出奇数偶数示例
  • php递归示例 php递归函数代码
  • php生成数组的使用示例 php全组合算法
  • php分割数组示例
  • php数组随机排序示例
  • PHP 强制下载文件示例代码
  • php动态生成函数示例
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • php输出1000以内质数(素数)示例
  • php 5.2.x 输出操作的细节
  • php遍历目录输出目录及其下的所有文件示例
  • php date函数格式化输出指定范围的时间
  • php foreach正序倒序输出示例代码
  • php foreach语句正序与倒序输出
  • PHP循环输出指定目录下的所有文件和文件夹路径例子(简单实用)
  • php标准输入与输出(STDIN、STDOUT、STDERR)
  • php foreach正序倒序输出示例
  • php输出字符串方法总结
  • PHP输出英文时间日期的安全方法(RFC 1123格式)
  • PHP使用range协议实现输出文件断点续传代码实例
  • php中单个数据库字段多列显示(单字段分页、横向输出)
  • PHP折线图的示例代码 可以输出汉字的php折线统计图
  • php导出csv数据(浏览器中输出提供下载或保存到文件)
  • 将php数组输出html表格的方法
  • PHP输出缓存ob系列函数详解
  • php输出缓存ob系列函数用法
  • php扫描图片像素获取每像素颜色值并输出
  • php 无限级分类,超级简单的无限级分类,支持输出树状图
  • 修改配置真正解决php文件上传大小限制问题(nginx+php)
  • IIS7配置PHP图解(IIS7+PHP_5.2.17/PHP_5.3.5)
  • PHP 5.4.19 和 PHP 5.5.3 发布及下载地址
  • PHP转换器 HipHop for PHP
  • 修改配置真正解决php文件上传大小限制问题(apache+php)
  • PHP 框架 Pop php
  • PHP去除html标签,php标记及css样式代码参考
  • PHP的JavaScript框架 PHP.JS
  • PHP 'ext/soap/php_xml.c'不完整修复存在多个任意文件泄露漏洞
  • php服务器探针显示php服务器信息
  • php安装完成后如何添加mysql扩展


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3