使用PHPExcel操作Excel用法实例分析
本文实例分析了使用PHPExcel操作Excel用法。分享给大家供大家参考。具体分析如下:
PHPExcel下载地址:
http://www.codeplex.com/PHPExcel
http://www.phpexcel.net
开发包Tests目录有详细使用实例 支持中文,注意文件编码 文件保存为utf-8
1.header部分:
1
2
3
4
|
header( "Content-Type:application/vnd.ms-excel" ); header( "Content-Disposition:attachment;filename=sample.xls" ); header( "Pragma:no-cache" ); header( "Expires:0" ); |
2.写excel:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
|
//Include class require_once ( 'Classes/PHPExcel.php' ); require_once ( 'Classes/PHPExcel/Writer/Excel2007.php' ); $objPHPExcel = new PHPExcel(); //Set properties 设置文件属性 $objPHPExcel ->getProperties()->setCreator( "Maarten Balliauw" ); $objPHPExcel ->getProperties()->setLastModifiedBy( "Maarten Balliauw" ); $objPHPExcel ->getProperties()->setTitle( "Office 2007 XLSX Test Document" ); $objPHPExcel ->getProperties()->setSubject( "Office 2007 XLSX Test Document" ); $objPHPExcel ->getProperties()->setDescription( "Test document for Office 2007 XLSX, generated using PHP classes." ); $objPHPExcel ->getProperties()->setKeywords( "office 2007 openxml php" ); $objPHPExcel ->getProperties()->setCategory( "Test result file" ); //Add some data 添加数据 $objPHPExcel ->setActiveSheetIndex(0); $objPHPExcel ->getActiveSheet()->setCellValue( 'A1' , 'Hello' ); //可以指定位置 $objPHPExcel ->getActiveSheet()->setCellValue( 'A2' , true); $objPHPExcel ->getActiveSheet()->setCellValue( 'A3' , false); $objPHPExcel ->getActiveSheet()->setCellValue( 'B2' , 'world!' ); $objPHPExcel ->getActiveSheet()->setCellValue( 'B3' , 2); $objPHPExcel ->getActiveSheet()->setCellValue( 'C1' , 'Hello' ); $objPHPExcel ->getActiveSheet()->setCellValue( 'D2' , 'world!' ); //循环 for ( $i = 1; $i <200; $i ++) { $objPHPExcel ->getActiveSheet()->setCellValue( 'A' . $i , $i ); $objPHPExcel ->getActiveSheet()->setCellValue( 'B' . $i , 'Test value' ); } //日期格式化 $objPHPExcel ->getActiveSheet()->setCellValue( 'D1' , time()); $objPHPExcel ->getActiveSheet()->getStyle( 'D1' )->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_DATE_YYYYMMDDSLASH); //Add comment 添加注释 $objPHPExcel ->getActiveSheet()->getComment( 'E11' )->setAuthor( 'PHPExcel' ); $objCommentRichText = $objPHPExcel ->getActiveSheet()->getComment( 'E11' )-> getText ()->createTextRun( 'PHPExcel:' ); $objCommentRichText ->getFont()->setBold(true); $objPHPExcel ->getActiveSheet()->getComment( 'E11' )-> getText ()->createTextRun( "\r\n" ); $objPHPExcel ->getActiveSheet()->getComment( 'E11' )-> getText ()->createTextRun( 'Total amount on the current invoice, excluding VAT.' ); //Add rich-text string 添加文字 可设置样式 $objRichText = new PHPExcel_RichText( $objPHPExcel ->getActiveSheet()->getCell( 'A18' ) ); $objRichText ->createText( 'This invoice is ' ); $objPayable = $objRichText ->createTextRun( 'payable within thirty days after the end of the month' ); $objPayable ->getFont()->setBold(true); $objPayable ->getFont()->setItalic(true); $objPayable ->getFont()->setColor( new PHPExcel_Style_Color( PHPExcel_Style_Color::COLOR_DARKGREEN ) ); $objRichText ->createText( ', unless specified otherwise on the invoice.' ); //Merge cells 合并分离单元格 $objPHPExcel ->getActiveSheet()->mergeCells( 'A18:E22' ); $objPHPExcel ->getActiveSheet()->unmergeCells( 'A18:E22' ); //Protect cells 保护单元格 $objPHPExcel ->getActiveSheet()->getProtection()->setSheet(true); //Needs to be set to true in order to enable any worksheet protection! $objPHPExcel ->getActiveSheet()->protectCells( 'A3:E13' , 'PHPExcel' ); //Set cell number formats 数字格式化 $objPHPExcel ->getActiveSheet()->getStyle( 'E4' )->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_CURRENCY_EUR_SIMPLE); $objPHPExcel ->getActiveSheet()->duplicateStyle( $objPHPExcel ->getActiveSheet()->getStyle( 'E4' ), 'E5:E13' ); //Set column widths 设置列宽度 $objPHPExcel ->getActiveSheet()->getColumnDimension( 'B' )->setAutoSize(true); $objPHPExcel ->getActiveSheet()->getColumnDimension( 'D' )->setWidth(12); //Set fonts 设置字体 $objPHPExcel ->getActiveSheet()->getStyle( 'B1' )->getFont()->setName( 'Candara' ); $objPHPExcel ->getActiveSheet()->getStyle( 'B1' )->getFont()->setSize(20); $objPHPExcel ->getActiveSheet()->getStyle( 'B1' )->getFont()->setBold(true); $objPHPExcel ->getActiveSheet()->getStyle( 'B1' )->getFont()->setUnderline(PHPExcel_Style_Font::UNDERLINE_SINGLE); $objPHPExcel ->getActiveSheet()->getStyle( 'B1' )->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_WHITE); //Set alignments 设置对齐 $objPHPExcel ->getActiveSheet()->getStyle( 'D11' )->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT); $objPHPExcel ->getActiveSheet()->getStyle( 'A18' )->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_JUSTIFY); $objPHPExcel ->getActiveSheet()->getStyle( 'A18' )->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER); $objPHPExcel ->getActiveSheet()->getStyle( 'A3' )->getAlignment()->setWrapText(true); //Set column borders 设置列边框 $objPHPExcel ->getActiveSheet()->getStyle( 'A4' )->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN); $objPHPExcel ->getActiveSheet()->getStyle( 'A10' )->getBorders()->getLeft()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN); $objPHPExcel ->getActiveSheet()->getStyle( 'E10' )->getBorders()->getRight()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN); $objPHPExcel ->getActiveSheet()->getStyle( 'D13' )->getBorders()->getLeft()->setBorderStyle(PHPExcel_Style_Border::BORDER_THICK); $objPHPExcel ->getActiveSheet()->getStyle( 'E13' )->getBorders()->getBottom()->setBorderStyle(PHPExcel_Style_Border::BORDER_THICK); //Set border colors 设置边框颜色 $objPHPExcel ->getActiveSheet()->getStyle( 'D13' )->getBorders()->getLeft()->getColor()->setARGB( 'FF993300' ); $objPHPExcel ->getActiveSheet()->getStyle( 'D13' )->getBorders()->getTop()->getColor()->setARGB( 'FF993300' ); $objPHPExcel ->getActiveSheet()->getStyle( 'D13' )->getBorders()->getBottom()->getColor()->setARGB( 'FF993300' ); $objPHPExcel ->getActiveSheet()->getStyle( 'E13' )->getBorders()->getRight()->getColor()->setARGB( 'FF993300' ); //Set fills 设置填充 $objPHPExcel ->getActiveSheet()->getStyle( 'A1' )->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID); $objPHPExcel ->getActiveSheet()->getStyle( 'A1' )->getFill()->getStartColor()->setARGB( 'FF808080' ); //Add a hyperlink to the sheet 添加链接 $objPHPExcel ->getActiveSheet()->setCellValue( 'E26' , 'www.phpexcel.net' ); $objPHPExcel ->getActiveSheet()->getCell( 'E26' )->getHyperlink()->setTooltip( 'Navigate to website' ); $objPHPExcel ->getActiveSheet()->getStyle( 'E26' )->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT); //Add a drawing to the worksheet 添加图片 $objDrawing = new PHPExcel_Worksheet_Drawing(); $objDrawing ->setName( 'Logo' ); $objDrawing ->setDescription( 'Logo' ); $objDrawing ->setPath( './images/officelogo.jpg' ); $objDrawing ->setHeight(36); $objDrawing ->setCoordinates( 'B15' ); $objDrawing ->setOffsetX(110); $objDrawing ->setRotation(25); $objDrawing ->getShadow()->setVisible(true); $objDrawing ->getShadow()->setDirection(45); $objDrawing ->setWorksheet( $objPHPExcel ->getActiveSheet()); //Play around with inserting and removing rows and columns $objPHPExcel ->getActiveSheet()->insertNewRowBefore(6, 10); $objPHPExcel ->getActiveSheet()->removeRow(6, 10); $objPHPExcel ->getActiveSheet()->insertNewColumnBefore( 'E' , 5); $objPHPExcel ->getActiveSheet()->removeColumn( 'E' , 5); //Add conditional formatting $objConditional1 = new PHPExcel_Style_Conditional(); $objConditional1 ->setConditionType(PHPExcel_Style_Conditional::CONDITION_CELLIS); $objConditional1 ->setOperatorType(PHPExcel_Style_Conditional::OPERATOR_LESSTHAN); $objConditional1 ->setCondition( '0' ); $objConditional1 ->getStyle()->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_RED); $objConditional1 ->getStyle()->getFont()->setBold(true); //Set autofilter 自动过滤 $objPHPExcel ->getActiveSheet()->setAutoFilter( 'A1:C9' ); //Hide "Phone" and "fax" column 隐藏列 $objPHPExcel ->getActiveSheet()->getColumnDimension( 'C' )->setVisible(false); $objPHPExcel ->getActiveSheet()->getColumnDimension( 'D' )->setVisible(false); //Set document security 设置文档安全 $objPHPExcel ->getSecurity()->setLockWindows(true); $objPHPExcel ->getSecurity()->setLockStructure(true); $objPHPExcel ->getSecurity()->setWorkbookPassword( "PHPExcel" ); //Set sheet security 设置工作表安全 $objPHPExcel ->getActiveSheet()->getProtection()->setPassword( 'PHPExcel' ); $objPHPExcel ->getActiveSheet()->getProtection()->setSheet(true); // This should be enabled in order to enable any of the following! $objPHPExcel ->getActiveSheet()->getProtection()->setSort(true); $objPHPExcel ->getActiveSheet()->getProtection()->setInsertRows(true); $objPHPExcel ->getActiveSheet()->getProtection()->setFormatCells(true); //Calculated data 计算 echo 'Value of B14 [=COUNT(B2:B12)]: ' . $objPHPExcel ->getActiveSheet()->getCell( 'B14' )->getCalculatedValue() . "\r\n" ; //Set outline levels $objPHPExcel ->getActiveSheet()->getColumnDimension( 'E' )->setOutlineLevel(1); $objPHPExcel ->getActiveSheet()->getColumnDimension( 'E' )->setVisible(false); $objPHPExcel ->getActiveSheet()->getColumnDimension( 'E' )->setCollapsed(true); //Freeze panes $objPHPExcel ->getActiveSheet()->freezePane( 'A2' ); //Rows to repeat at top $objPHPExcel ->getActiveSheet()->getPageSetup()->setRowsToRepeatAtTopByStartAndEnd(1, 1); //Set data validation 验证输入值 $objValidation = $objPHPExcel ->getActiveSheet()->getCell( 'B3' )->getDataValidation(); $objValidation ->setType( PHPExcel_Cell_DataValidation::TYPE_WHOLE ); $objValidation ->setErrorStyle( PHPExcel_Cell_DataValidation::STYLE_STOP ); $objValidation ->setAllowBlank(true); $objValidation ->setShowInputMessage(true); $objValidation ->setShowErrorMessage(true); $objValidation ->setErrorTitle( 'Input error' ); $objValidation ->setError( 'Number is not allowed!' ); $objValidation ->setPromptTitle( 'Allowed input' ); $objValidation ->setPrompt( 'Only numbers between 10 and 20 are allowed.' ); $objValidation ->setFormula1(10); $objValidation ->setFormula2(20); $objPHPExcel ->getActiveSheet()->getCell( 'B3' )->setDataValidation( $objValidation ); //Create a new worksheet, after the default sheet 创建新的工作标签 $objPHPExcel ->createSheet(); $objPHPExcel ->setActiveSheetIndex(1); //Set header and footer. When no different headers for odd/even are used, odd header is assumed. 页眉页脚 $objPHPExcel ->getActiveSheet()->getHeaderFooter()->setOddHeader( '&C&HPlease treat this document as confidential!' ); $objPHPExcel ->getActiveSheet()->getHeaderFooter()->setOddFooter( '&L&B' . $objPHPExcel ->getProperties()->getTitle() . '&RPage &P of &N' ); //Set page orientation and size 方向大小 $objPHPExcel ->getActiveSheet()->getPageSetup()->setOrientation(PHPExcel_Worksheet_PageSetup::ORIENTATION_LANDSCAPE); $objPHPExcel ->getActiveSheet()->getPageSetup()->setPaperSize(PHPExcel_Worksheet_PageSetup::PAPERSIZE_A4); //Rename sheet 重命名工作表标签 $objPHPExcel ->getActiveSheet()->setTitle( 'Simple' ); //Set active sheet index to the first sheet, so Excel opens this as the first sheet $objPHPExcel ->setActiveSheetIndex(0); //Save Excel 2007 file 保存 $objWriter = new PHPExcel_Writer_Excel2007( $objPHPExcel ); $objWriter ->save( str_replace ( '.php' , '.xlsx' , __FILE__ )); //Save Excel 5 file 保存 require_once ( 'Classes/PHPExcel/Writer/Excel5.php' ); $objWriter = new PHPExcel_Writer_Excel5( $objPHPExcel ); $objWriter ->save( str_replace ( '.php' , '.xls' , __FILE__ )); //1.6.2新版保存 require_once ( 'Classes/PHPExcel/IOFactory.php' ); $objWriter = PHPExcel_IOFactory::createWriter( $objPHPExcel , 'Excel2007' ); $objWriter ->save( str_replace ( '.php' , '.xls' , __FILE__ )); |
3.读excel
1
2
3
4
|
//Include class require_once ( 'Classes/PHPExcel/Reader/Excel2007.php' ); $objReader = new PHPExcel_Reader_Excel2007; $objPHPExcel = $objReader ->load( "05featuredemo.xlsx" ); |
4.读写csv
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
require_once ( "05featuredemo.inc.php" ); require_once ( 'Classes/PHPExcel/Writer/CSV.php' ); require_once ( 'Classes/PHPExcel/Reader/CSV.php' ); require_once ( 'Classes/PHPExcel/Writer/Excel2007.php' ); //Write to CSV format 写 $objWriter = new PHPExcel_Writer_CSV( $objPHPExcel ); $objWriter ->setDelimiter( ';' ); $objWriter ->setEnclosure( '' ); $objWriter ->setLineEnding( "\r\n" ); $objWriter ->setSheetIndex(0); $objWriter ->save( str_replace ( '.php' , '.csv' , __FILE__ )); //Read from CSV format 读 $objReader = new PHPExcel_Reader_CSV(); $objReader ->setDelimiter( ';' ); $objReader ->setEnclosure( '' ); $objReader ->setLineEnding( "\r\n" ); $objReader ->setSheetIndex(0); $objPHPExcelFromCSV = $objReader ->load( str_replace ( '.php' , '.csv' , __FILE__ )); //Write to Excel2007 format $objWriter2007 = new PHPExcel_Writer_Excel2007( $objPHPExcelFromCSV ); $objWriter2007 ->save( str_replace ( '.php' , '.xlsx' , __FILE__ )); |
5.写html
1
2
3
4
5
6
|
require_once ( "05featuredemo.inc.php" ); require_once ( 'Classes/PHPExcel/Writer/HTML.php' ); //Write to HTML format $objWriter = new PHPExcel_Writer_HTML( $objPHPExcel ); $objWriter ->setSheetIndex(0); $objWriter ->save( str_replace ( '.php' , '.htm' , __FILE__ )); |
6.写pdf
1
2
3
4
5
6
7
8
|
require_once ( "05featuredemo.inc.php" ); require_once ( 'Classes/PHPExcel/IOFactory.php' ); //Write to PDF format $objWriter = PHPExcel_IOFactory::createWriter( $objPHPExcel , 'PDF' ); $objWriter ->setSheetIndex(0); $objWriter ->save( str_replace ( '.php' , '.pdf' , __FILE__ )); //Echo memory peak usage echo date ( 'H:i:s' ). " Peak memory usage: " .(memory_get_peak_usage(true) / 1024 / 1024). " MB\r\n" ; |
使用PHPExcel操作Excel用法实例分析的更多相关文章
- Jackson的用法实例分析
这篇文章主要介绍了Jackson的用法实例分析,用于处理Java的json格式数据非常实用,需要的朋友可以参考下 通俗的来说,Jackson是一个 Java 用来处理 JSON 格式数据的类库,其性能 ...
- Python实现的选择排序算法原理与用法实例分析
Python实现的选择排序算法原理与用法实例分析 这篇文章主要介绍了Python实现的选择排序算法,简单描述了选择排序的原理,并结合实例形式分析了Python实现与应用选择排序的具体操作技巧,需要的朋 ...
- php中使用PHPExcel操作excel(xls)文件
读取中文的xls.csv文件会有问题,网上找了下资料,发现PHPExcel类库好用,官网地址:http://phpexcel.codeplex.com/ 1.读取xls文件内容 代码如下 复制代码 ...
- php中return的用法实例分析
本文实例讲述了php中return的用法.分享给大家供大家参考.具体分析如下: 首先,它的意思就是返回;return()是语言结构而不是函数,仅在参数包含表达式时才需要用括号将其括起来.当返回一个变量 ...
- C#中sizeof的用法实例分析
这篇文章主要介绍了C#中sizeof的用法,包括了常见的用法及注释事项,需要的朋友可以参考下. sizeof是C#中非常重要的方法,本文就以实例形式分析C#中sizeof的用法.分享给大家供大家参 ...
- PHP消息队列用法实例分析
这篇文章主要介绍了PHP消息队列用法,结合实例形式分析了PHP消息队列用于Linux下进程间通信的相关技巧,需要的朋友可以参考下 该消息队列用于linux下,进程通信 队列状态信息:具体参考手册
- ASP.NET中Dictionary基本用法实例分析
本文实例讲述了ASP.NET中Dictionary基本用法.分享给大家供大家参考,具体如下: //Dictionary位于System.Collections.Generic命名空间之下 /* * ...
- Javascript自定义事件功能与用法实例分析
原文地址:https://www.jb51.net/article/127776.htm 本文实例讲述了javascript自定义事件功能与用法.分享给大家供大家参考,具体如下: 概述 自定义事件很难 ...
- C/C++中对链表操作的理解&&实例分析
链表概述 链表是一种常见的重要的数据结构.它是动态地进行存储分配的一种结构.它可以根据需要开辟内存单元.链表有一个“头指针”变量,以head表示,它存放一个地址.该地址指向一个元素.链表中每一个元素称 ...
随机推荐
- 《图解设计模式》读书笔记8-2 MEMENTO模式
目录 Memento模式 示例代码 程序类图 代码 角色和类图 模式类图 角色 思路拓展 接口可见性 保存多少个Memento 划分Caretaker和Originator的意义 Memento模式 ...
- sql时间类型相关
1.现在时间 NOW() 示例: select * from users where date<now() 2.时间相减 INTERVAL ' DAY 示例: ' DAY 3.timestamp ...
- axios 获取不到数据错误
1.问题: 打算学习下vue,但是vue-resource作者已经不更新了,并且大家都建议用axios来进行前后端交互,所以就从学习axios开始. 但是在使用 axios 的过程中,自己写的接口竟然 ...
- C++ 全面刨析使用指针方法 _new _delete
指针 #include<iostream> using namespace std; int main() { ; int* pn;//声明 int* pn = &avr;//初始 ...
- 关于addEventListener中事件函数的this指向问题
看代码: //定义一个可见的盒子用于绑定点击事件 var box = document.getElementById('box'); box.x = 'box' //设置执行函数的对象属性 funct ...
- CEPH安装(CentOS 7)
以包含四个节点的集群为例,其中包括一个 ceph-deploy 管理节点和一个三节点的Ceph存储集群. 下图中每个节点代表一台机器. 安装 CEPH 部署工具 执行如下命令: sudo yum in ...
- Log4net使用(二)
转:http://www.cnblogs.com/basilwang/archive/2006/06/09/421868.html Log4net同时按照日期和大小生成RollingFile和访问Sy ...
- 知识点C++
比较2个字符串的大小…… s1=s2,strcmp(s1,s2) == ; s1>s2, strcmp(s1,s2) == ; s1<s2, strcmp(s1,s2) == -; str ...
- 13 (H5*) JS第三天 数组、函数
目录 1:数组的定义和创建方式 2:数组的总结 3:for循环遍历数组 4:数组的案例 5:冒泡排序 6:函数的定义 7:函数的参数 8:函数的返回值 复习 <script> /* * * ...
- 问题 F: 超超的自闭意思
问题 F: 超超的自闭意思 时间限制: 1 Sec 内存限制: 128 MB提交: 80 解决: 10[提交] [状态] [命题人:jsu_admin] 题目描述 质数定义为在大于1的自然数中,除 ...