FastExcelWriter v.6
|
FastExcelWriter是FastExcelphp项目的一部分,由
- FastExcelWriter-创建Excel电子表格
- FastExcelReader-阅读Excel电子表格
- FastExCeltemplator-生成XLSX模板的Excel电子表格
- FastExcellaravel-特殊Laravel Edition
介绍
该库设计为轻巧,超快速,需要最少的内存使用量。
FastExcelWriter以XLSX格式创建Excel兼容电子表格(Office 2007+),并支持许多功能:
- 获取UTF-8编码输入
- 多个工作表
- 支持货币/日期/数字单元格式,公式和主动超链接
- 支持大多数用于细胞,行,列 – 颜色,边框,字体等的样式选项。
- 您可以设置行的高度和列的宽度(包括自动宽度计算)
- 您可以在XLSX文件中添加公式,笔记和图像
- 支持使用/没有密码的工作簿和表格保护
- 支持页面设置 – 页面边距,页面大小
- 插入多个图表
- 支持数据验证和条件格式
跳到:
- 版本6的更改
- 版本6.1的重要更改
- 版本5的更改
- 版本5.8的重要更改
- 简单示例
- 高级示例
- 添加笔记
- 添加图像
- 工作簿
- 工作簿设置
- 设置工作簿的元数据
- 为临时文件设置目录
- 帮助者方法
- 床单
- 创建,选择和删除表
- 表设置
- 页面设置
- 行的设置
- 列的设置
- 自动列宽度
- 组/轮廓行和列
- 定义名称范围
- 冷冻窗格和自动滤器
- 设置活跃的纸张和单元格
- 打印设置
- 写作
- 用第与直接编写行
- 直接写入细胞
- 编写单元格值
- 合并细胞
- 细胞格式
- 公式
- 超链接
- 使用丰富的文字
- 样式
- 样式属性作为数组
- 定义样式属性的班级样式
- 细胞样式
- 行样式
- 列样式
- 其他列选项
- 应用样式(流利的界面)
- 应用边界
- 应用字体
- 应用颜色
- 应用文字样式
- 图表
- 简单用法
- 组合图
- 多个图表
- 图表类型
- 有用的图表方法
- 保护工作簿和床单
- 工作簿保护
- 保护工作表
- 细胞锁定/解锁
- 数据验证
- 简单用法
- 定义过滤器
- 检查价值类型
- 自定义过滤器
- 所有数据验证设置
- 超过64K验证规则
- 条件格式
- 简单用法
- 一般细胞值检查
- 表达
- 梯度填充,具体取决于值(颜色等级)
- 单元格内的数据带(数据库)
- API参考
- FastExcelWriter vs phpspreadsheet
- 您想支持FastExcelWriter吗?
安装
使用composer将FastExcelWriter安装到您的项目中:
composer require avadim/fast-excel-writer
版本6的更改
- 数据验证支持
版本6.1的重要更改
-
Sheet::setRowOptions(),Sheet::setColOptions(),Sheet::setRowStyles()和Sheet::setColStyles()已弃用,而不是它们应该使用其他功能:setRowStyle(),setRowStyleArray(),setRowDataStyle(),setRowDataStyleArray()setColStyle()setColStyleArray(),setColDataStyle(),setColDataStyleArray() -
Sheet::setRowStyle()和Sheet::setColStyle()已更改,现在它们为整个行或列设置了样式(即使它们为空)
版本5的更改
- 一般新闻是图表支持
版本5.8的重要更改
在v.5.8之前
$ sheet -> writeCell ( 12345 ); // The number 12345 will be written into the cell $ sheet -> writeCell ( \' 12345 \' ); // The number 12345 will also be written here
在版本5.8及以后
$ sheet -> writeCell ( 12345 ); // The number 12345 will be written into the cell $ sheet -> writeCell ( \' 12345 \' ); // Here the string \'12345\' will be written into the cell
如果要保留以前的向后兼容性行为,则在创建工作簿时应使用选项“ auto_convert_number”。
$ excel = Excel:: create ([ \' Sheet1 \' ], [ \' auto_convert_number \' => true ]); $ sheet = $ excel -> sheet (); $ sheet -> writeCell ( \' 12345 \' ); // String \'12345\' will be automatically converted to a number
版本4的更改
- 现在图书馆的工作速度更快
- 添加了一个流利的界面以应用样式。
- 新方法和代码重构
用法
您可以在下面或在/演示文件夹中找到使用示例
简单示例
use \\ avadim \\ FastExcelWriter \\ Excel ; $ data = [ [ \' 2003-12-31 \' , \' James \' , \' 220 \' ], [ \' 2003-8-23 \' , \' Mike \' , \' 153.5 \' ], [ \' 2003-06-01 \' , \' John \' , \' 34.12 \' ], ]; $ excel = Excel:: create ([ \' Sheet1 \' ]); $ sheet = $ excel -> sheet (); // Write heads $ sheet -> writeRow ([ \' Date \' , \' Name \' , \' Amount \' ]); // Write data foreach ( $ data as $ rowData ) { $ rowOptions = [ \' height \' => 20 , ]; $ sheet -> writeRow ( $ rowData , $ rowOptions ); } $ excel -> save ( \' simple.xlsx \' );
另外,您可以将生成的文件下载到客户端(发送到浏览器)
$ excel = Excel:: create (); $ sheet = $ excel -> sheet (); $ sheet -> writeCell ( 12345 ); // write integer $ sheet -> writeCell ( 123.45 ); // write float $ sheet -> writeCell ( \' 12345 \' ); // write string $ sheet -> writeCell ( true ); // write boolean value $ sheet -> writeCell ( fn () => $ sheet -> getCurrentCell ()); // write result of function $ excel -> download ( \' download.xlsx \' );
高级示例
use \\ avadim \\ FastExcelWriter \\ Excel ; $ head = [ \' Date \' , \' Name \' , \' Amount \' ]; $ data = [ [ \' 2003-12-31 \' , \' James \' , \' 220 \' ], [ \' 2003-8-23 \' , \' Mike \' , \' 153.5 \' ], [ \' 2003-06-01 \' , \' John \' , \' 34.12 \' ], ]; $ headStyle = [ \' font \' => [ \' style \' => \' bold \' ], \' text-align \' => \' center \' , \' vertical-align \' => \' center \' , \' border \' => \' thin \' , \' height \' => 24 , ]; $ excel = Excel:: create ([ \' Sheet1 \' ]); $ sheet = $ excel -> sheet (); // Write the head row (sets style via array) $ sheet -> writeHeader ( $ head , $ headStyle ); // The same result with new fluent interface $ sheet -> writeHeader ( $ head ) -> applyFontStyleBold () -> applyTextAlign ( \' center \' , \' center \' ) -> applyBorder (Style:: BORDER_STYLE_THIN ) -> applyRowHeight ( 24 ); // Sets columns options - format and width (the first way) $ sheet -> setColFormats ([ \' @date \' , \' @text \' , \' 0.00 \' ]) -> setColWidths ([ 12 , 14 , 5 ]); // The seconds way to set columns options $ sheet // column and options -> setColDataStyle ( \' A \' , [ \' format \' => \' @date \' , \' width \' => 12 ]) // column letter in lower case -> setColDataStyle ( \' b \' , [ \' format \' => \' @text \' , \' width \' => 24 ]) // column can be specified by number -> setColDataStyle ( 3 , [ \' format \' => \' 0.00 \' , \' width \' => 15 , \' color \' => \' #090 \' ]) ; // The third way - all options in multilevel array (first level keys point to columns) $ sheet -> setColDataStyle ([ \' A \' => [ \' format \' => \' @date \' , \' width \' => 12 ], \' B \' => [ \' format \' => \' @text \' , \' width \' => 24 ], \' C \' => [ \' format \' => \' 0.00 \' , \' width \' => 15 , \' color \' => \' #090 \' ], ]); $ rowNum = 1 ; foreach ( $ data as $ rowData ) { $ rowOptions = [ \' height \' => 20 , ]; if ( $ rowNum % 2 ) { $ rowOptions [ \' fill-color \' ] = \' #eee \' ; } $ sheet -> writeRow ( $ rowData , $ rowOptions ); } $ excel -> save ( \' simple.xlsx \' );
添加笔记
Excel和注释中当前有两种评论类型(请参阅线程注释和注释之间的区别)。注释是Excel中的旧样式评论(在浅黄色背景上的文字)。您可以使用方法addNote()向任何单元格添加注释
$ sheet -> writeCell ( \' Text to A1 \' ); $ sheet -> addNote ( \' A1 \' , \' This is a note for cell A1 \' ); $ sheet -> writeCell ( \' Text to B1 \' )-> addNote ( \' This is a note for B1 \' ); $ sheet -> writeTo ( \' C4 \' , \' Text to C4 \' )-> addNote ( \' Note for C1 \' ); // If you specify a range of cells, then the note will be added to the left top cell $ sheet -> addNote ( \' E4:F8 \' , \" This note \\n will added to E4 \" ); // You can split text into multiple lines $ sheet -> addNote ( \' D7 \' , \" Line 1 \\n Line 2 \" );
您可以更改一些注释选项。注释的允许选项是:
-
宽度– 默认值为
\'96pt\' -
高度– 默认值是
\'55.5pt\' - fill_color-默认值为
\'#FFFFE1\' -
显示– 默认值为
false
$ sheet -> addNote ( \' A1 \' , \' This is a note for cell A1 \' , [ \' width \' => \' 200pt \' , \' height \' => \' 100pt \' , \' fill_color \' => \' #ffcccc \' ]); // Parameters \"width\" and \"height\" can be numeric, by default these values are in points // The \"fill_color\" parameter can be shortened $ noteStyle = [ \' width \' => 200 , // equivalent to \'200pt\' \' height \' => 100 , // equivalent to \'100pt\' \' fill_color \' => \' fcc \' , // equivalent to \'#ffcccc\' ]; $ sheet -> writeCell ( \' Text to B1 \' )-> addNote ( \' This is a note for B1 \' , $ noteStyle ); // This note is visible when the Excel workbook is displayed $ sheet -> addNote ( \' C8 \' , \' This note is always visible \' , [ \' show \' => true ]);
另外,您可以在笔记中使用丰富的文字
$ richText = new \\ avadim \\ FastExcelWriter \\ RichText ( \' here is <c=f00>red</c> and <c=00f>blue</c> text \' ); $ sheet -> addNote ( \' C8 \' , $ richText );
有关使用丰富文本的更多信息,请参见此处:使用丰富的文本
添加图像
您可以在base64中将图像插入到本地文件,URL或图像字符串中
$ sheet -> addImage ( $ cell , $ imageFile , $ imageStyle ); // Insert an image to the cell A1 from local path $ sheet -> addImage ( \' A1 \' , \' path/to/file \' ); // Insert an image to the cell A1 from URL $ sheet -> addImage ( \' A1 \' , \' https://*sit*e.com*/image.jpg \' ); // Insert an image to the cell A1 from base64 string $ sheet -> addImage ( \' A1 \' , \' ... \' ); // Insert an image to the cell B2 and set with to 150 pixels (height will change proportionally) $ sheet -> addImage ( \' B2 \' , \' path/to/file \' , [ \' width \' => 150 ]); // Set height to 150 pixels (with will change proportionally) $ sheet -> addImage ( \' C3 \' , \' path/to/file \' , [ \' height \' => 150 ]); // Set size in pixels $ sheet -> addImage ( \' D4 \' , \' path/to/file \' , [ \' width \' => 150 , \' height \' => 150 ]); // Add hyperlink to the image $ sheet -> addImage ( \' D4 \' , \' path/to/file \' , [ \' width \' => 150 , \' height \' => 150 , \' hyperlink \' => \' https://www.g**oog*le.com/ \' ]);
图像样式的可用键:
- “宽度” – 图像的宽度
- “高度” – 图像高度
- “超链接” – 超链接的URL
- \’x\’ – 相对于单元格的左边界相对于像素的偏移
- \’y\’ – 相对于单元格的顶部边界相对于像素的偏移
重要:在MS Excel中,值“ X”不能大于亲属单元的列宽度,并且值“ y”不能大于行高度
共享字符串
默认情况下,字符串直接写入床单。这会增加文件大小,但会加快数据编写并节省内存。如果要将字符串写入共享字符串XML,则需要使用“共享_String”选项。
$ excel = Excel:: create ([], [ \' shared_string \' => true ]);
FastExcelWriter vs phpspreadsheet
Phpspreadsheet是一个完美的库,具有阅读和编写许多文档格式的精彩功能。 FastExcelWriter只能写入XLSX格式,但是它的内存使用量很快,并且使用最少。
FastExcelWriter :
- 7-9倍更快
- 使用8-10次使用的记忆更少
- 支持编写大型100k+行电子表格
Phpspreadsheet的基准(无样式的生成)
| 行X Cols | 时间 | 记忆 |
|---|---|---|
| 1000 x 5 | 0.98秒 | 2,048 kb |
| 1000 x 25 | 4.68秒 | 14,336 kb |
| 5000 x 25 | 23.19秒 | 77,824 kb |
| 10000 x 50 | 105.8秒 | 256,000 kb |
FastExcelwriter的基准(无样式的生成)
| 行X Cols | 时间 | 记忆 |
|---|---|---|
| 1000 x 5 | 0.19秒 | 2,048 kb |
| 1000 x 25 | 1.36秒 | 2,048 kb |
| 5000 x 25 | 3.61秒 | 2,048 kb |
| 10000 x 50 | 13.02秒 | 2,048 kb |
您想支持FastExcelWriter吗?
如果您发现此包装有用,则可以支持我喝杯咖啡:
- USDT(TRC20)tssufvjehqbjckeygnnr1cpswy6jznbzk7
- USDT(ERC20)0x5244519D65035AF868A010C2F68A086F473FC82B
- ETH 0x5244519D65035AF868A010C2F68A08A086F473FC82B
或者只是在github上给我一颗星星:)
