Home >PHP Framework >ThinkPHP >How to use thinkphp to generate reports
With the development of informatization and digitization, data analysis and report generation have become an indispensable part of enterprise management and decision-making. In web development, thinkphp, as a lightweight PHP framework, also provides some convenient report generation methods. This article will introduce how to use thinkphp to generate reports.
1. Prerequisites
Before using thinkphp to generate reports, you need to have the following environment:
2. Ideas
The main ideas for using thinkphp to generate reports are as follows:
1. Query the database to obtain the data that needs to be generated;
3. Example
The following is a sample code to generate a simple sales report based on the thinkphp framework and PHPExcel plug-in:
1. Write in the controller The following code:
use PHPExcel_IOFactory; use PHPExcel; class ReportController extends Controller { public function index() { $model = new OrderModel(); $data = $model->select(); $objPHPExcel = new PHPExcel(); $objPHPExcel->setActiveSheetIndex(0); $objPHPExcel->getActiveSheet()->setCellValue('A1', '订单号'); $objPHPExcel->getActiveSheet()->setCellValue('B1', '商品名称'); $objPHPExcel->getActiveSheet()->setCellValue('C1', '商品单价'); $objPHPExcel->getActiveSheet()->setCellValue('D1', '商品数量'); $objPHPExcel->getActiveSheet()->setCellValue('E1', '订单总金额'); $num = 2; $total = 0; foreach ($data as $value) { $objPHPExcel->getActiveSheet()->setCellValue('A' . $num, $value['order_sn']); $objPHPExcel->getActiveSheet()->setCellValue('B' . $num, $value['goods_name']); $objPHPExcel->getActiveSheet()->setCellValue('C' . $num, $value['goods_price']); $objPHPExcel->getActiveSheet()->setCellValue('D' . $num, $value['goods_num']); $objPHPExcel->getActiveSheet()->setCellValue('E' . $num, $value['total_amount']); $total += $value['total_amount']; $num++; } $num--; $objPHPExcel->getActiveSheet()->setCellValue('A' . ($num + 2), '总计'); $objPHPExcel->getActiveSheet()->setCellValue('E' . ($num + 2), $total); $filename = '订单列表-' . date('YmdHis', time()) . '.xls'; 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; } }
2. Write the following code in the Model:
use think\Model; class OrderModel extends Model { protected $table = 'order'; }
Finally, add the index method of the Report controller in the menu, you can access http://localhost/Report /index generates sales reports.
4. Notes
In short, using the thinkphp framework and PHPExcel plug-in to generate reports is a very practical function that can provide strong data support for business management and decision-making. I hope this article can help readers in need.
The above is the detailed content of How to use thinkphp to generate reports. For more information, please follow other related articles on the PHP Chinese website!