PHP中创建和编辑Excel表格的方法
时间:2022-07-27
本文章向大家介绍PHP中创建和编辑Excel表格的方法,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
要使用纯PHP创建或编辑Excel电子表格,我们将使用PHPExcel库,它可以读写许多电子表格格式,包括xls,xlsx,ods和csv。在我们继续之前,仔细检查您的服务器上是否有PHP 5.2或更高版本以及安装了以下PHP扩展:php_zip,php_xml和php_gd2。
创建电子表格
创建电子表格是PHP应用程序中最常见的用例之一,用于将数据导出到Excel电子表格。查看以下代码,了解如何使用PHPExcel创建示例Excel电子表格:
// Include PHPExcel library and create its object
require('PHPExcel.php');
$phpExcel = new PHPExcel;
// Set default font to Arial
$phpExcel- getDefaultStyle()- getFont()- setName('Arial');
// Set default font size to 12
$phpExcel- getDefaultStyle()- getFont()- setSize(12);
// Set spreadsheet properties – title, creator and description
$phpExcel - getProperties()- setTitle("Product list");
$phpExcel - getProperties()- setCreator("Voja Janjic");
$phpExcel - getProperties()- setDescription("PHP Excel spreadsheet testing.");
// Create the PHPExcel spreadsheet writer object
// We will create xlsx file (Excel 2007 and above)
$writer = PHPExcel_IOFactory::createWriter($phpExcel, "Excel2007");
// When creating the writer object, the first sheet is also created
// We will get the already created sheet
$sheet = $phpExcel - getActiveSheet();
// Set sheet title
$sheet- setTitle('My product list');
// Create spreadsheet header
$sheet - getCell('A1')- setValue('Product');
$sheet - getCell('B1')- setValue('Quanity');
$sheet - getCell('C1')- setValue('Price');
// Make the header text bold and larger
$sheet- getStyle('A1:D1')- getFont()- setBold(true)- setSize(14);
// Insert product data
// Autosize the columns
$sheet- getColumnDimension('A')- setAutoSize(true);
$sheet- getColumnDimension('B')- setAutoSize(true);
$sheet- getColumnDimension('C')- setAutoSize(true);
// Save the spreadsheet
$writer- save('products.xlsx');
如果要下载电子表格而不是将其保存到服务器,请执行以下操作:
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="file.xlsx"');
header('Cache-Control: max-age=0');
$writer- save('php://output');
编辑现有电子表格
在PHP中编辑电子表格与创建电子表格类似:
// Include PHPExcel library and create its object
require('PHPExcel.php');
// Load an existing spreadsheet
$phpExcel = PHPExcel_IOFactory::load('products.xlsx');
// Get the first sheet
$sheet = $phpExcel - getActiveSheet();
// Remove 2 rows starting from the row 2
$sheet - removeRow(2,2);
// Insert one new row before row 2
$sheet- insertNewRowBefore(2, 1);
// Create the PHPExcel spreadsheet writer object
// We will create xlsx file (Excel 2007 and above)
$writer = PHPExcel_IOFactory::createWriter($phpExcel, "Excel2007");
// Save the spreadsheet
$writer- save('products.xlsx');
准备电子表格进行打印
要准备电子表格进行打印,我们将设置纸张方向,尺寸和边距:
$sheet- getPageSetup()- setOrientation(PHPExcel_Worksheet_PageSetup::ORIENTATION_LANDSCAPE);
$sheet - getPageSetup()- setPaperSize(PHPExcel_Worksheet_PageSetup::PAPERSIZE_A4);
$sheet- getPageMargins()- setTop(1);
$sheet - getPageMargins()- setRight(0.75);
$sheet - getPageMargins()- setLeft(0.75);
$sheet - getPageMargins()- setBottom(1);
将PHPExcel与Laravel一起使用
PHPExcel库也可以在Laravel框架中使用。查看以下PHP包(此处)并通过Composer安装它。完成安装步骤后,您可以使用以下代码将数据从数据库导出到Excel电子表格中:
Excel::create('Products', function($excel) {
// Set the title
$excel- setTitle('Product list');
// Set the creator
$excel- setCreator('Voja Janjic');
// Set description
$excel- setDescription('PHP Excel spreadsheet testing');
$excel- sheet('Products', function($sheet) {
// Get data from the database
$products = Product::all();
// Generate header row
$sheet- row(1, array(
'ID',
'Product',
'Price',
'Quantity',
));
// Generate data rows
$i = 2;
foreach($products as $product) {
$sheet- row($i, array(
$product- product_id,
$product- product_name,
$product- price,
$variety- quantity,
));
$i++;
}
});
})- export('xlsx');
- php概述
- php教程
- php环境搭建
- PHP书写格式
- php变量
- php常量
- PHP注释
- php数组
- php字符串 string
- PHP整型 integer
- PHP浮点型 float
- php布尔型
- php数据类型之数组
- php数据类型之对象
- php数据类型之null
- php数据类型之间的转换
- php运算符
- php表达式
- PHP循环控制
- PHP流程控制
- php函数
- php全局变量
- PHP魔术变量
- php命名空间
- php 日期
- PHP包含文件
- php文件
- PHP 文件上传
- php Cookies
- php Sessions
- php email
- php安全email
- php错误处理
- PHP异常处理
- php过滤器
- PHP 高级过滤器
- php json
- php 表单
- PHP MySQL 简介
- PHP 连接 MySQL
- php创建数据库
- php 创建表
- php mysq 插入数据
- PHP MySQL 插入多条数据
- PHP MySQL 预处理语句
- php mysql 读取数据
- php mysql where
- PHP MySQL Order By
- PHP MySQL Update
- PHP MySQL Delete
- php ODBC
- 手把手带你玩转 AWS Lambda
- Guava 中的 Stopwatch 是个什么鬼?
- Mybatis接口Mapper内的方法为啥不能重载?
- 基于K-Means聚类算法的主颜色提取
- 扩展之Tensorflow2.0 | 21 Keras的API详解(下)池化、Normalization层
- 一个真实问题,搞定三个冷门pandas函数
- conda管理C源代码程序的时候总是出现库文件冲突或者缺失
- 如何获取非模式生物KEGG PATHWAY的基因集并用clusterProfile做GSEA?
- 通过视频着色进行自监督跟踪
- Python爬虫:一些常用的爬虫技巧总结
- 带你用 Python 实现自动化群控(入门篇)
- Chrome终于上线这项重磅功能,中国用户苦等多年!
- YOLO 算法最全综述:从 YOLOv1 到 YOLOv5
- 《JavaScript ES6 函数式编程入门经典》读书笔记
- Java9-Reactive Stream API响应式编程