php怎么导出大量数据的Excel

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php怎么导出大量数据的Excel相关的知识,希望对你有一定的参考价值。

php导出大量数据Excel的具体操作步骤如下:

1、使用phpstudy搭建一个测试平台,直接访问数据库。

2、下载的phpcms安装包拷贝到IIS目录,开通访问,即可搭建成功。

3、登录网站后台,系统权限,文件目录以及数据库等功能,进行管理。

4、在phpcms后台,扩展,数据库工具,数据库导出,程序池选择phpcmsv9,开始备份数据。

5、打开IIS网站目录,在D:\\wwwroot\\kmxy\\wwwroot\\caches\\bakup\\default文件夹,查看导出的数据库文件。

6、登录phpmyadmin,选择数据库导出,选择Excel格式,即可导出。

参考技术A 用这个吧:PHPExcel
步骤:

1.百度:phpexcel,点击第一个结果;

2.进入官网后,找到右边的download按钮,下载,下载完成的是一个压缩文件,解压放到你的项目目录里,根据个人情况而定;

3.因为这里给大家做演示,所以建了一个测试文件,有点基础的都能明白是怎么回事,下面进入代码;

4.
//引入PHPExcel库文件(路径根据自己情况)
include './phpexcel/Classes/PHPExcel.php';
//创建对象
$excel = new PHPExcel();
//Excel表格式,这里简略写了8列
$letter = array('A','B','C','D','E','F','F','G');
//表头数组
$tableheader = array('学号','姓名','性别','年龄','班级');

//填充表头信息
for($i = 0;$i < count($tableheader);$i++)
$excel->getActiveSheet()->setCellValue("$letter[$i]1","$tableheader[$i]");


5.
//表格数组
$data = array(
array('1','小王','男','20','100'),
array('2','小李','男','20','101'),
array('3','小张','女','20','102'),
array('4','小赵','女','20','103')
);
//填充表格信息
for ($i = 2;$i <= count($data) + 1;$i++)
$j = 0;
foreach ($data[$i - 2] as $key=>$value)
$excel->getActiveSheet()->setCellValue("$letter[$j]$i","$value");
$j++;



6.
//创建Excel输入对象
$write = new PHPExcel_Writer_Excel5($excel);
header("Pragma: public");
header("Expires: 0");
header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
header("Content-Type:application/force-download");
header("Content-Type:application/vnd.ms-execl");
header("Content-Type:application/octet-stream");
header("Content-Type:application/download");;
header('Content-Disposition:attachment;filename="testdata.xls"');
header("Content-Transfer-Encoding:binary");
$write->save('php://output');

7.打开页面,刷新的时候会弹出对话框,让你选择文件保存路径和文件名称,直接放在了桌面上,

8.打开表格后,数据和格式跟代码中的一致,说明PHP导出的Excel是正确的。如果出现错误,检查一下你的表格数组和数据数组吧。本回答被提问者采纳
参考技术B

php导出大量数据到Excel,可以通过生成多个Excel文件,然后压缩成压缩包解决。

方案是:假如我们数据库有10w条数据,每2000条数据生成一个Excel文件,这样每次只要从数据库里查询出2000条数据即可,一定要分页去查询。

原因:主要是数据库性能和写文件性能。分页查询可以解决数据库压力的问题, 生成多个文件可以解决单个文件太大,后期维护Excel文件的问题。 

要注意的:

           1. 在导出逻辑文件开头,一定要声明 set_time_limit(0) ,防止脚本超时;

           2. 每个文件生成后,适当的sleep一下,让程序休息一下下;

           3. 因为一次导出最后要将生成的多个Excel文件打包成一个压缩包,所以要删除掉生成的Excel文件,节省服务器存储空间;

下面是我实际工作中,写的一个php导出大量数据到Excel的代码,你可以参考一下:

参考技术C php导出大量数据的Excel:
PHP从数据库分多次读取100万行记录,和分多次将100万行写入文本文件都没问题
Excel可以支持100万行记录,Excel 2003最大支持65536行,从2007版开始支持104万行了,目前2007的盗版应该比较普及了-_-! 问清楚客户是什么版本。
要导出excel的理由是非常充分和正确的,应该继续坚持。业务人员最熟悉的就是Excel,实在不熟悉现学现用也比别的快。只是要注意,当数据量达到10万行这个级别时,Excel的公式填充将会非常非常慢,如果再有LOOKUP()公式,基本上十分钟内处理CPU满载进程管理器杀不掉的状态,这时候其实xampp + phpmyadmin是一个易用性和性能都最平衡的选择
PHPExcel输出的是Excel XML格式,有个XML头和尾,中间是数据Body,需要将100万行都赋值给一个数组才可以调用PHPExcel->write(),这容易导致PHP执行超时或者内存超限,不妨调整一下php.ini配置,把超时时间和内存限制都改到很大
如果是输出csv格式,那就太简单了,你的问题可能是没给字段内容加引号,加上引号再调用fputcsv试试?其实fputcsv做的事情特别简单,你甚至可以不管它,自己把CSV文件的每一行拼接好了之后用file_put_contents写入
参考技术D

简介:可以利用工具软件导出成Excel文件

工具原料:Apache+php+mysql网站运行环境,phpMyAdmin v4.6.2

    下载phpMyAdmin v4.6.2软件后解压放在网站根目录

    用root用户和密码登入phpMyAdmin,在左边栏点击要导出的数据库,然后点击要导出的数据表,最后点击导出如图所示。

    进入导出页面后如图按图中红色标注的操作

    另外还要注意选择的是要保存的文件的字符集:如图所示才能保证保存出来的文件不会出现乱码

    最后点击执行按钮,OK.

大量数据导出excel(csv)的实现

<?php
/**
 * 大量数据导出excel(csv)的实现。
 * Created by PhpStorm.
 * User: Huming
 * Date: 2017-04-16
 * Time: 14:04
 *  */

//使用MS sqlserver数据测试的
require_once \'MSSqlServerHelper.php\';
$sqlHelper = new MSSqlServerHelper();
set_time_limit(0);
ini_set(\'memory_limit\', \'128M\');

date_default_timezone_set("PRC");
$fileName = date(\'YmdHis\');

//浏览器直接下载,加头文件
//header(\'Content-Type: application/vnd.ms-execl\');
//header(\'Content-Disposition: attachment;filename="\' . $fileName . \'.csv"\');

$begintime = microtime(true);

//打开php标准输出流
//以写入追加的方式打开
//$fp = fopen(\'php://output\', \'ab\');
//对于大数据,使用在服务器生成文件,完成后下载
$path = $_SERVER[\'DOCUMENT_ROOT\'] . "\\\\output\\\\";

$fp = fopen("$path$fileName.csv", "a");


//我们要获取$nums条数据,每次取$step条,分步执行,避免内存溢出
//如果线上环境无法支持一次性读取$step条数据,可反$step相应减小。
$step = 10000;
//指定要取的记录数
//$nums =80000;
//动态获取总共的记录数
$rowscount = $sqlHelper->execute_dql_rowsCount("select count(id)  from temp_sjbb");
$nums = $rowscount;
//$nums = 22;



//设置标题
/*$title = array(\'ID\', \'用户名\', \'用户年龄\', \'用户描述\', \'用户手机\', \'用户QQ\', \'用户邮箱\', \'用户地址\');
foreach($title as $key => $item) {
    $title[$key] = iconv(\'UTF-8\', \'GBK\', $item);
}
//标题写到标准输出中
fputcsv($fp, $title);*/


//分批获取,写入大数据,防止内存溢出
for ($s = 1; $s <= ceil($nums / $step); ++$s) {
    $start = (($s - 1) * $step) + 1;
    $end = ($s * $step) > $nums ? $nums : $s * $step;

    $sql = "select * from (select *,rOW_NUMBER() OVER (ORDER BY id asc) AS counts  from temp_sjbb ) as b";
    $sql .= " where counts >= ";
    $sql .= $start;
    $sql .= " and counts <= ";
    $sql .= $end;
    // echo  $sql;
    $result = $sqlHelper->execute_dql_array($sql);

    for ($i = 0; $i < count($result); $i++) {

        //第一次循环把列标题打印出来
        if ($s == 1 && $i == 0) {
            $arr = array();
            foreach ($result[$i] as $key => $values) {
                $arr[] = $key;
            }
            fputcsv($fp, $arr);
        }

        fputcsv($fp, $result[$i]);
    }


    //刷新缓冲区
    unset($result);
    ob_flush();
    flush();
}
fclose($fp);

//打印下载路径
echo "<a href=\'./output/$fileName.csv\'>点击下载</a>";

$endtime = microtime(true);
echo \'用时:\', $endtime - $begintime;

测试字段数为81个的8万余条数据。

  

以上是关于php怎么导出大量数据的Excel的主要内容,如果未能解决你的问题,请参考以下文章

php怎么导出大量数据的Excel

php怎么导出大量数据的Excel

php怎么导出大量数据的Excel

php怎么导出大量数据的Excel

php怎么导出大量数据的Excel,phpexcel

PHP 用PHPExcel往数据库导入大量数据