php 导出大量表格数据导出,PHPExcel 导出表格大量数据速度最快

/**

*兑换码下载实例

*/

public function excelCode($data)

{

$name     = '兑换码';

$header = ['兑换码‘]; //表头,名称可自定义

$this->excelExport($name,$header,$data);

}

/***

* excel表格导出

* @param string $fileName 文件名称

* @param array $headArr 表头名称

* @param array $data 要导出的数据

* @author static7

*/

public function excelExport($fileName, $headArr, $list)

{

//对数据进行检验

if (empty($list) || !is_array($list))

{

die("data must be a array");

}

//检查文件名

if (empty($fileName))

{

exit;

}

$date = date("Y_m_d_h:i", time());

$fileName .= "_{$date}.xls";

//加载PHPExcel类

vendor("Classes.PHPExcel");

//创建PHPExcel对象,注意,不能少了

$objPHPExcel =new \PHPExcel();

$objProps = $objPHPExcel->getProperties();

//设置表头

$key = ord("A");

foreach ($headArr as $v)

{

$colum = chr($key);

$objPHPExcel->setActiveSheetIndex(0)->setCellValue($colum . '1', $v);

$key += 1;

}

$column = 2;

$objActSheet = $objPHPExcel->getActiveSheet();

foreach ($list as $key => $rows)

{     //行写入

$span = ord("A");

foreach ($rows as $keyName => $value)

{    // 列写入

$j = chr($span);

$objActSheet->setCellValue($j . $column, $value);

$span++;

}

$column++;

}

$fileName = iconv("utf-8", "gb2312", $fileName);

//重命名表

// $objPHPExcel->getActiveSheet()->setTitle('test');

//设置活动单指数到第一个表,所以Excel打开这是第一个表

$objPHPExcel->setActiveSheetIndex(0);

ob_end_clean();

ob_start();

header('Content-Type: application/vnd.ms-excel');

header("Content-Disposition: attachment;filename=\"$fileName\"");

header('Cache-Control: max-age=0');

$objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');

$objWriter->save('php://output'); //文件通过浏览器下载

exit;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的示例代码,使用 PHPExcel 库来导出数据库中的大量数据: ```php // 引入 PHPExcel 库 require_once 'PHPExcel.php'; // 连接数据库 $servername = "localhost"; $username = "your_username"; $password = "your_password"; $dbname = "your_database"; $conn = new mysqli($servername, $username, $password, $dbname); if ($conn->connect_error) { die("Connection failed: " . $conn->connect_error); } // 查询数据库中的数据 $sql = "SELECT * FROM your_table"; $result = $conn->query($sql); // 创建一个新的 Excel 文件 $objPHPExcel = new PHPExcel(); // 设置工作表标题 $objPHPExcel->getActiveSheet()->setTitle('Export Data'); // 添加表头 $objPHPExcel->getActiveSheet()->setCellValue('A1', 'ID'); $objPHPExcel->getActiveSheet()->setCellValue('B1', 'Name'); $objPHPExcel->getActiveSheet()->setCellValue('C1', 'Email'); $objPHPExcel->getActiveSheet()->setCellValue('D1', 'Phone'); // 添加数据 if ($result->num_rows > 0) { $i = 2; while($row = $result->fetch_assoc()) { $objPHPExcel->getActiveSheet()->setCellValue('A'.$i, $row["id"]); $objPHPExcel->getActiveSheet()->setCellValue('B'.$i, $row["name"]); $objPHPExcel->getActiveSheet()->setCellValue('C'.$i, $row["email"]); $objPHPExcel->getActiveSheet()->setCellValue('D'.$i, $row["phone"]); $i++; } } // 设置单元格自动宽度 foreach(range('A','D') as $columnID) { $objPHPExcel->getActiveSheet()->getColumnDimension($columnID) ->setAutoSize(true); } // 输出 Excel 文件 header('Content-Type: application/vnd.ms-excel'); header('Content-Disposition: attachment;filename="export_data.xls"'); header('Cache-Control: max-age=0'); $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); $objWriter->save('php://output'); // 关闭数据库连接 $conn->close(); ``` 你可以将上述代码保存为 PHP 文件,通过浏览器访问该文件即可下载导出的 Excel 文件。请注意,这只是一个简单的示例代码,实际情况下你需要根据自己的数据表结构和需求进行修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值