PHP导出数据到CSV文件函数/方法

如果不清楚什么是CSV文件,可看如下文章介绍  CSV格式的是什么文件?CSV是什么的缩写?

/**
 * 导出数据到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] . ""
";
    }

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

应用举例:

$header = array(
	‘0‘		=> ‘参数ID‘,
	‘1‘		=> ‘参数名称‘,
	‘2‘		=> ‘统计次数‘,
	‘3‘		=> ‘统计次数百分比‘,
	‘4‘		=> ‘唯一用户数‘,
	‘5‘		=> ‘唯一用户数百分比‘,
	‘6‘		=> ‘人均次数‘
);

/** 列表项 */
foreach ($list as $key => $row){
	$csvList[] = array(
		‘0‘		=> $row[‘param_key‘],
		‘1‘		=> $row[‘param_name‘],
		‘2‘		=> $row[‘nums‘],
		‘3‘		=> $row[‘percent_nums‘] . ‘%‘,
		‘4‘		=> $row[‘total_users‘],
		‘5‘		=> $row[‘percent_total_users‘] .‘%‘,
		‘6‘		=> $row[‘avg‘]
	);
}

/** 导出csv */
$title = str_replace(‘ ‘,‘-‘, $title);
export_csv($csvList, $header, $title);
时间: 2024-11-05 20:43:26

PHP导出数据到CSV文件函数/方法的相关文章

mysql 导出数据到csv文件的命令

1.导出本地数据库数据到本地文件 mysql -A service_db -h your_host -utest -ptest mysql> select * from t_apps where created>'2012-07-02 00:00:00' into outfile /tmp/apps.csv 2.导出远程数据库数据到本地文件 mysql -A service_db -h your_host -utest -ptest -ss -e "SELECT * from t_a

MySQL导出数据到csv文件

select * from users into OUTFILE 'F:/Develop/MySQL57/Uploads/users.csv' CHARACTER SET utf8 FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' ESCAPED BY '"' LINES TERMINATED BY '\r\n'; 说明:数据格式化:关于数据格式化的问题,需要给导出的字段传递一些参数, 这个参数是根据RFC4180文档设置的,该文档

php导出数据为CSV文件DEMO

代码示例: private function _download_send_headers($filename) { // disable caching $now = gmdate("D, d M Y H:i:s"); header("Expires: Tue, 03 Jul 2001 06:00:00 GMT"); header("Cache-Control: max-age=0, no-cache, must-revalidate, proxy-re

Jsoup学习笔记9:Jsoup 解析saz文件,读取其中的htm文件到字符串,提取字符串中的数据写入csv文件中

本篇笔记将上篇笔记的操作做些改进,不再把saz文件中的htm文件解析出来,而是不解压直接读取其中的数据成字符串,基本思路如下: 1.自定义一个从文本文件读取内容到字符串的类:解析saz文件中的htm文档,将文件的内容读取到字符串中 2.自定义利用Jsoup解析htm字符串的类:利用Jsoup解析传入的htm字符串,将解析结果写入csv文件中 3.解析时,指定好文件路径,直接调用上面的两个工具类即可 示例代码如下: package com.daxiang.saztest; /** * 自定义一个从

用程序读取CSV文件的方法

CSV全称 Comma Separated values,是一种用来存储数据的纯文本文件格式,通常用于电子表格或数据库软件.用Excel或者Numbers都可以导出CSV格式的数据. CSV文件的规则 0 开头是不留空,以行为单位.1 可含或不含列名,含列名则居文件第一行. 2 一行数据不垮行,无空行. 3 以半角符号,作分隔符,列为空也要表达其存在. 4 列内容如存在,,则用""包含起来. 5 列内容如存在""则用""""包

Oracle通过PL/SQL Developer导出数据为CSV格式,VARCHAR2类型的字段如果存入的是数值(例如3307830000004059)太长,最后一位会被置为0

问题描述: Oracle通过PL/SQL Developer导出数据为CSV格式,VARCHAR2类型的字段如果存入的是数值(例如3307830000004059)太长,CSV文件该列会用科学计数法表示,即使选择该列,点击数据--.>分列,固定宽度,列数据格式选择文本,最后一位仍然会被置为0. 解决方法: Oracle通过PL/SQL Developer导出数据为CSV格式,新建一个Excel文件,点击数据-->自文本,选择之前导出的CSV文件,文件类型分隔符号,选择逗号,[选中所有列],然后

C语言处理CSV文件的方法(一)

什么是CSV文件 CSV是 Comma-separated values (逗号分隔值)的首字母缩写,它通常是以逗号且不仅限于逗号分隔各个值,我们都叫他CSV. 看下面的例子: China, Shanghai, Pudong, Zhang San, 200000, 1234567 BMW; GER; 300000; RMB; i530 从上面两个例子可以看出,可以用不同的分隔符来分隔数据:数据的类型可以不同:长度任意. 由多行这样的CSV记录组成的文件叫做CSV文件(逗号分隔值文件).当然,他们

CodeIgniterCodeigniter+PHPExcel导出数据到Excel文件

解压压缩包里的Classes文件夹中的内容到application\libraries\目录下,目录结构如下:--application\libraries\PHPExcel.php--application\libraries\PHPExcel(文件夹)修改application\libraries\PHPExcel\IOFactory.php文件--将其类名从PHPExcel_IOFactory改为IOFactory,遵从CI类命名规则.--将其构造函数改为public $this->loa

C#导出数据到Excel通用的方法类

导出数据到Excel通用的方法类,请应对需求自行修改. 资源下载列表 using System.Data; using System.IO; namespace IM.Common.Tools { public class Export { public string Encoding = "UTF-8"; System.Web.HttpResponse response = System.Web.HttpContext.Current.Response; public void Ec