使用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表示,它存放一个地址.该地址指向一个元素.链表中每一个元素称 ...
随机推荐
- 从DT时代云栖大会聊聊恒生电子
从IT到DT,除了HOMS和配资,本文结合互联网金融的背景,帮助读者对恒生电子600570了解更多. 马云在2015杭州·云栖大会Computing Conference发表致辞时多次强调DT(Dat ...
- 【BASIS系列】SAP 批量锁住用户和TCODE的方法
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[BASIS系列]SAP 批量锁住用户和TCOD ...
- mssql 堆叠注入
添加用户 exec master.dbo.xp_cmdshell 'net user leeww 123456 /add' 提升权限 exec master.dbo.xp_cmdshell 'net ...
- STL关联容器值hashtable
hashtable(散列表)是一种数据结构,在元素的插入,删除,搜索操作上具有常数平均时间复杂度O(1); hashtable名词 散列函数:负责将某一元素映射为索引. 碰撞(collision):不 ...
- Maven构建Struts2框架的注意事项
[本人出错点:404,就是在web.xml配置文件中少配置了struts.xml的路径] 1.创建Maven,搭建Struts框架,实现最基本的Hello World 在pom.xml中加入strut ...
- POJ-2456.Aggressivecows.(二分求解最大化最小值)
本题大意:在坐标轴上有n个点,现在打算在这n个点上建立c个牛棚,由于牛对厂主的分配方式表示很不满意,它很暴躁,所以它会攻击离它很近的牛来获得快感,这件事让厂主大大知道了,他怎么可能容忍?所以他决定有策 ...
- java基础常问面试题
1.面向对象和面向过程的区别 面向过程 :面向过程性能比面向对象高. 因为类调用时需要实例化,开销比较大,比较消耗资源,所以当性能是最重要的考量因素的时候,比如单片机.嵌入式开发.Linux/Unix ...
- P3452 [POI2007]BIU-Offices
传送门 首先能想到 $n^2$ 的做法 枚举所有两点,看看是否有边相连,如果没有说明它们一定要在同一集合,用并查集维护一下就行 注意到如果没有边这个条件,其实就相当于问补图有边 所以题意可以转化为,求 ...
- Python 数据分析中金融数据的来源库和简单操作
目录 金融数据 pandas-datareader TuShare 金融学图表 案例 金融数据 数据分析离不开数据的获取,这里介绍几种常用的获取金融方面数据的方法. pandas-datareader ...
- 回溯---N皇后
N 皇后 51. N-Queens (Hard) 题目描述: 在n*n的矩阵中摆放n个皇后,并且每个皇后不能在同一列,同一个对角线上,求所有的n皇后解. 思路分析: 一行一行地摆放,在确定一行 ...