php如何导出数据库的数据并转为excel表格

后端开发   发布日期:2023年11月09日   浏览次数:325

本文小编为大家详细介绍“php如何导出数据库的数据并转为excel表格”,内容详细,步骤清晰,细节处理妥当,希望这篇“php如何导出数据库的数据并转为excel表格”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

一、准备工作

在开始我们的操作之前,需要安装PHP环境和PHPExcel类库,PHPExcel是一个强大的PHPExcel类库,用来生成各类型的Excel文件。安装PHP环境和PHPExcel类库的方法这里不再赘述,如果您还没有安装的话,可以参考PHP官网和PHPExcel官网进行安装和使用。

二、连接数据库

连接数据库是一项非常重要的操作,我们需要确保连接正常以及数据库表格的正确选择。以下是通过mysqli连接MySQL数据库的基本代码示例:

$conn = mysqli_connect($servername, $username, $password, $dbname);
if (!$conn) {
    die("连接失败: " . mysqli_connect_error());
}

三、查询数据库数据

在完成数据库连接的工作后,我们需要通过SQL语句查询数据库数据并进行处理。以下是一个简单的SQL语句示例:

$sql = "SELECT * FROM `table_name`";
$result = mysqli_query($conn, $sql);

通过使用mysqli_query函数,我们可以轻松地对数据库进行查询,并获取到查询结果$result。

四、生成Excel表格

在获取到数据库查询结果之后,我们接下来需要将其转换为Excel表格的形式。以下是PHPExcel类库的基本代码示例:

//创建PHPExcel对象
$objPHPExcel = new PHPExcel();

//设置Excel文件属性
$objPHPExcel->getProperties()
    ->setCreator("your name")
    ->setLastModifiedBy("your name")
    ->setTitle("title")
    ->setSubject("subject")
    ->setDescription("description")
    ->setKeywords("keywords")
    ->setCategory("category");

//设置当前活动表格
$objPHPExcel->setActiveSheetIndex(0);

//循环遍历查询结果,将数据写入Excel表格
$i = 1;
while ($row = mysqli_fetch_array($result)) {
    $objPHPExcel->getActiveSheet()->setCellValue('A' . $i, $row['column1']);
    $objPHPExcel->getActiveSheet()->setCellValue('B' . $i, $row['column2']);
    $i++;
}

使用以上代码,我们可以轻松地将MySQL查询结果转换为Excel表格的格式,同时,将数据输入到Excel表格中。

五、输出或下载Excel文件

在将数据写入Excel表格之后,我们可以选择将其输出到浏览器或者下载到本地进行保存。以下是实现这一操作的基本代码示例:

输出到浏览器:

header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="filename.xls"');
header('Cache-Control: max-age=0');
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output');

下载到本地:

$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('file_path/filename.xls');

以上就是php如何导出数据库的数据并转为excel表格的详细内容,更多关于php如何导出数据库的数据并转为excel表格的资料请关注九品源码其它相关文章!