为什么很简单的excelexcel 判断数值范围结果会出错?

访问本页面,您的浏览器需要支持JavaScript11728人阅读
这里有关于excel文件的几个概念需要跟大家说明一下,这几个概念对于我们的后续编程是很有帮助的:
1.工作簿:在excel环境中用来存储数据并处理数据的文件,又称为excel文件或excel文档,
&& &在一个工作簿中,可以拥有多张不同类型的工作表,无论有多少张工作表,在将其保存时,都将会保存在一个工作簿文件中,而不是按照工作表的个数来保存的
&& &在默认情况下,每一个工作簿文件会包含三个工作表文件:sheet1,sheet2,sheet3
2.工作表:是由多行和多列所构成的一个二维表格,行号的编号是自上而下从1开始,列号则从左到右采用字母编号,从A开始
3.单元格:行坐标和列坐标做指定的位置,称为单元格,列名和行号做组成的名称为单元格名称
大家好,利用这个时间,带领大家学习excel报表技术在企业项目中的使用。
在网站的管理后台经常会使用到报表的生成和读取,其中Excel是最为常见的报表格式之一,今天我们就来学习在php中的如何操作Excel报表。
在正式学习之前,我们先来演示一下excel报表技术在真实项目中的使用案例?
案例1:excel报表技术在电子税务系统中的使用
&& &&& &①统计纳税人每一项税务的纳税情况:城市维护建设税,企业所得税等
在php中生成excel报表文件,主要是通过header()向浏览器发送头信息来完成的
php生成Excel报表文件的方式有如下几种:
好,现在我们就通过php程序来生成一个简单excel文件
//首先,在php文件的开头,通过header()定义输出的文件类型为excel文件
//定义输出的文件类型,表示输出的是一个excel文件
header(&Content-type:application/vnd.ms-excel&);
//定义输出的文件名,表示输出的文件名为test.xls,如果文件名为中文,用iconv函数进行转码
header(&Content-Disposition:filename=test.xls&);
//为什么要加\t和\n呢?主要是通过程序的手段来模拟table键和回车键
echo &test1\t&;&& &&& &//& \t:table键 ,通过程序的手段来模拟table键和回车键的按下
echo &test2\t\n&;&& &//&& &\t\n:table键并换行
echo &test1\t&;
echo &test2\t\n&;
echo &test1\t&;
echo &test2\t\n&;
echo &test1\t&;
echo &test2\t\n&;
echo &test1\t&;
echo &test2\t\n&;
echo &test1\t&;
echo &test2\t\n&;
//其实在大部分情况下,可以将数据从数据库中取出,然后按照每一列数据结束后加\t,每一行数据结束后加\n的方法echo出来
//给excel表格的每一列添加一个标题
echo &ID\t&;
echo &客户简称\t&;
echo &客户全名\t&;
echo &联系人\t&;
echo &联系电话\t&;
echo &传真\t&;
echo &地址\t\n&;
mysql_connect(&localhost&,&root&,&&);
mysql_select_db(&jxc2008&);
mysql_query(&set names 'utf8'&);
$sql=&select * from kehu order by id desc&;
$rec=mysql_query($sql);//返回一个结果集
$row_num=mysql_num_rows($rec);//结果集中的行数
$col_num=mysql_num_fields($rec);//结果集中的列数
while($row=mysql_fetch_array($rec)){//从结果集中逐行获取记录
&& &for($col=0;$col&$col_$col++){
&& &&& &if($col==($col_num-1)){//excel文件中列的数字编号从0开始,总列数-1 对应excel文件中最大列的编号
&& &&& &&& &echo $row[$col].&\t\n&;//如果是最后一列,加上 \n 来模拟回车键
&& &&& &}else{
&& &&& &&& &echo $row[$col].&\t&;//每一行数据逐列输出到excel文件单元格中,不是最后一列时,加上 \t 来模拟tab键
通过运行如下程序,就生成了一个简单的excel文件。通过这种方式来生成excel文件呢,有他的优点,也有他的缺点:
优点:上面这种格式,相对比较简单,因为比较单一
缺点:对于控制生成的excel表格样式很不方便,读取excel文件和不方便
案例:通过&table&表格的方式来生成一个excel文件:省略
缺点:更复杂点的报表就要麻烦点了,要在模板中一个个单元格自己去放置 StyleID 值
问题:虽然使用php的header()可以直接生成excel,但是对于控制生成的excel样式(如:居中对齐,背影颜色等)是很不方便的,所以这里推荐一个最为流行的Excel类库-PHPExcel
PHPExcel类库是一个非常强大的php类库,基本上能解决一切的excel问题,企业中对excel报表的处理大多是采用此类库来完成的
此类库可到其官网 /PHPExcel 去下载,目前最新版本为1.7.7,我这里已经将其下载下来了,
将其解压到我的web应用中,解压后发现里面有三个文件夹:
&& &classess:此文件夹中是PHPExcel核心类库文件,我们对excel报表的处理都是通过此文件夹中的类文件来完成的,注意:所有的类名都是以PHPExcel_*开头的
&& &&& &特点:所有的文件都是一个类
&& &&& &&& && 所有的类名都是以PHPExcel_*开头
&& &Documentation:这个文件夹中存放的是PHPExcel类库的英文说明文档
&& &Tests:是一些小的测试案例,这些小案例对于我们入门是非常有帮助的
首先,我们打开一个测试文件来快速体验一把。执行测试文件后。会提示我们进行下载
这里有关于excel文档的两个概念需要跟大家解释一下:
&& &工作簿:包含多个工作表的excel文档,也就是说,工作簿==excel文档,我们所建立的excel文档的名称就是工作簿的名称
&& &工作表:有行有列的二维表,多个工作表组成了一个工作簿
好,知道了这些呢,我们就来解读一下这个php测试文件
PHPExcel实现了autoloader自动加载机制,这意味着我们不需要引入PHPExcel文件夹下的每个类库文件,只需要在文件中引入PHPExcel初始化类库文件就可以了,自动加载类,将自动引入其它需要的类库文件
为了简化PHPExcel类的概念,PHPExcel类代表你的工作簿
对于常见的excel报表操作,我们需要掌握如下几个类库就可以了:
1.工作簿对象类:PHPExcel
&& &2.工作表对象类:PHPExcel_WorkSheet
&& &&& &3.样式对象类:PHPExcel_Style
&& &&& &&& &4.对齐方式对象类:PHPExcel_Style_Alignment
&& &&& &&& &5.字体对象类:PHPExcel_Style_Font
&& &&& &&& &&& &6.颜色对象类:PHPExcel_Style_Color
&& &&& &7.单元格类:PHPExcel_Cell
8.读写文件的类:PHPExcel_IOFactory
&& &9.读文件的类:PHPExcel_Reader_Excel5
&& &10.写文件的类:PHPExcel_Writer_Excel5
大家可以看的出来,我写的有一定的层级关系,为什么这么写呢?是因为在很多情况下低层级的类依赖于其上一层级的类
对于常见的excel报表操作,我们需要掌握如下几个类库就可以了:
(1)PHPExcel:工作簿对象
&& &excel文档处理对象主要用来管理我们的excel文档,怎么来管理(通过属性和方法来管理)?大家知道,类主要是由属性和方法来组成,通过php程序的手段来管理excel文档,其实就是通过本对象的属性和方法来管理,下面我们就来看一下PHPExcel类中都有那些属性和方法,这些属性和方法主要用来管理excel文档的那些方面
&& &getProperties():获得当前活动状态工作表的属性对象,返回属性对象
&& &getActiveSheet():获得当前活动状态的工作表,返回工作表对象
&& &getActiveSheetIndex():获得当前活动状态工作表的索引值,返回int
&& &setActiveSheetIndex():设置当前活动状态工作表的索引,返回工作表对象
&& &getSheetByName():通过工作表名称得到当前工作表对象,返回工作表对象
&& &getDefaultStyle():获得excel文档默认的样式(所有工作表的样式),返回样式对象
&& &createSheet():在当前活动工作表后创建一个新的工作表
&& &getSheetCount():获得excel文档中工作表的数量,返回int
&& &getSheetNames():获得excel文档中所有工作表名称组成的数组
(2)PHPExcel_Worksheet:工作表对象
&& &工作表对象,主要用来管理我们的工作表,怎么管理?也是通过属性和方法来管理,但是工作表对象大部分情况下可通过excel文档对象来获取
&& &toArray():把工作表中的数据转换成数组
&& &fromArray():从数组中获取数据填充到工作表,返回工作表对象
&& &getCell():获得单元格对象
&& &getCellByColumnAndRow():通过列索引和行索引获得指定单元格,返回单元格对象
&& &getDefaultStyle():获得工作表默认的样式,返回样式对象
&& &getHighestColumn():获得工作表的最大列,返回列的名称
&& &getColumnDimension():获得当前列
&& &getStyle():获得指定单元格的样式,返回样式对象
&& &getParent():获得父类对象,返回excel文档对象
&& &getTitle():获得工作表的标题或名称,返回字符串类型
&& &setCellValue():设置单元格的值,返回工作表对象或单元格对象,完全取决于参数的值
&& &setCellValueByColumnAndRow():通过列索引和行索引设置单元格的值,返回类型同上
&& &setCellValueExplicit():设置单元格的值,并显示指定数据类型,返回工作表对象
&& &setCellValueExplicitByColumnAndRow():通过列和行索引设置单元格值
&& &setTitle():设置工作表标题
(3)PHPExcel_Cell:单元格对象
(3)PHPExcel_Style:样式对象,主要用来设置单元格的样式:对齐方式、字体、边框、填充等,跟我们之前学过的css样式差不多,在这里如果想要设置对齐方式、字体大小、边框颜色、等等都是通过样式对象来完成的
&& &getActiveCell():获得当前活动的单元格的名称,返回string;如,A1
&& &getActiveSheet():获得当前活动的工作表,返回工作表对象
&& &getAlignment():获得对齐方式对象,返回对齐方式对象
&& &getBorders():获得边框对象,返回边框对象
&& &getFill():获得填充对象
&& &getFont():获得字体对象
&& &setFont():设置字体,返回样式对象
(3)PHPExcel_Style_Alignment:对齐方式对象
&& &getHorizontal():获得水平居中方式
&& &getVertical():获得垂直居中方式
&& &setHorizontal():设置水平居中方式,返回对齐方式对象
&& &setVertical():设置垂直居中方式,返回对齐方式对象
&& &居中方式:
&& &&& &HORIZONTAL_CENTER
&& &&& &HORIZONTAL_CENTER_CONTINUOUS
&& &&& &HORIZONTAL_GENERAL
&& &&& &HORIZONTAL_JUSTIFY
&& &&& &HORIZONTAL_LEFT
&& &&& &HORIZONTAL_RIGHT
&& &&& &VERTICAL_BOTTOM
&& &&& &VERTICAL_CENTER
&& &&& &VERTICAL_JUSTIFY
&& &&& &VERTICAL_TOP
(3)PHPExcel_Style_Font:字体对象
&& &setBold():设置字体加粗
&& &setColor():设置字体颜色
&& &setItalic():设置字体倾斜
&& &setName():设置字体名
&& &setSize():设置字体大小
&& &setUnderline():设置字体下划线
(4)PHPExcel_Writer_Excel5:写操作对象,主要用来输出xls文件
&& &save(工作簿文件名):将工作簿对象中的数据保存到一个工作簿文件中
(4)PHPExcel_Writer_Excel2007:写操作对象,主要用于输出xlsx文件
&& &save(工作簿文件名):将工作簿对象中的数据保存到一个工作簿文件中
(5)PHPExcel_Reader_Excel5:读操作对象,主要用于输入xls文件
&& &canRead():当前reader对象是否能够读工作簿文件
&& &load():从一个工作簿文件中加载工作簿对象,也就是将工作簿文件中的数据加载到工作簿对象中来管理
(6)PHPExcel_IOFactory:读写操作对象
&& &createReader():根据参数的不同,创建不同的读对象:主要作用是读取工作簿文件中的数据
&& &createWriter():根据参数的不同,返回不同的写对象:主要作用是将PHPExcel工作簿对象中的数据写入到一个工作簿文件中
&& &load():从工作簿文件中加载PHPExcel工作簿对象,即:将工作簿文件中数据加载到PHPExcel工作簿对象中来管理
PHPExcel对象:是一个工作簿对象
include_once &PHPExcel/Writer/Excel5.php&;//主要用于其它低版本,且文件名后缀为xls的文件,如果我们希望生成后缀名为xls格式的excel文件,建议引入此类库
include_once &PHPExcel/Writer/Excel2007.php&;//主要用于excel;式,文件名后缀为xlsx的excel文件,如果我们希望生成后缀名为xlsx格式的excel文件,建议引入此类库
$objWriter&=&new&PHPExcel_Writer_Excel5($objExcel);//创建一个文件格式写入对象实例,此对象主要用来写入内容到指定格式的文件,如,写入内容到后缀名为xls格式的excel文件等,用于其它板式的格式
$objWriter&=&new&PHPExcel_Writer_Excel2007($objExcel);//创建一个文件格式写入对象实例,此对象主要用来写入内容到指定格式的文件,如,写入内容到后缀名为xls格式的excel文件等,用于excel;式
$objWriter-&setOffice2003Compatibility(true);//兼容office2003
//设置文档基本属性&
$objProps&=&$objExcel-&getProperties();&&//得到PHPExcel_document文档对象
$objProps-&setCreator(&Zeal&Li&);& && & //设置作者
$objProps-&setLastModifiedBy(&Zeal&Li&);&//设置最后修改时间
$objProps-&setTitle(&Office&XLS&Test&Document&);&//设置标题
$objProps-&setSubject(&Office&XLS&Test&Document,&Demo&);//设置主题
$objProps-&setDescription(&Test&document,&generated&by&PHPExcel.&);//描&
$objProps-&setKeywords(&office&excel&PHPExcel&);&//关键字
$objProps-&setCategory(&Test&);&//分类
$objExcel-&setActiveSheetIndex(0);//设置用户打开excel文件时,看到的首张sheet,如果没有设置,默认为最后一次操作的sheet
$objActSheet-&setTitle('测试Sheet');//设置当前活动的工作簿名称
//根据单元格名称设置单元格内容,由PHPExcel根据传入的内容自动判断单元格的内容类型&
$objActSheet-&setCellValue('A1',&'字符串内容');&&//&字符串内容&
$objActSheet-&setCellValue('A2',&26);&&&&&&&&&&&&//&数值&
$objActSheet-&setCellValue('A3',&true);&&&&&&&&&&//&布尔值&
$objActSheet-&setCellValue('A4',&'=SUM(A2:A2)');&//&公式&
/显式指定单元格的内容类型为字符串类型&
$objActSheet-&setCellValueExplicit('A5','487584',PHPExcel_Cell_DataType::TYPE_STRING);
//合并单元格&
$objActSheet-&mergeCells('B1:C22');&
//设置列的宽度&
$objActSheet-&getColumnDimension('B')-&setAutoSize(true);
$objActSheet-&getColumnDimension('A')-&setWidth(30);
//设置行的高度
$objPHPExcel-&getActiveSheet()-&getRowDimension('2')-&setRowHeight(11.5);
//格式:主要用来对单元格进行操作,如,设置字体、设置对齐方式、设置边框等
$objStyleA5&=&$objActSheet-&getStyle('A5');//获取A5单元格的样式
//设置单元格的字体
$objFontA5&=&$objStyleA5-&getFont();&//获得字体
$objFontA5-&setName('宋体');//设置字体名称&
$objFontA5-&setSize(10);&&//设置字体大小
$objFontA5-&setBold(true);//设置字体加粗
$objFontA5-&getColor()-&setARGB('FF999999');//设置字体颜色
//设置单元格的对齐方式&
$objAlignA5&=&$objStyleA5-&getAlignment();//获得对齐方式
$objAlignA5-&setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);//水平居右&
$objAlignA5-&setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);//垂直居中
//设置单元格的边框&
$objBorderA5&=&$objStyleA5-&getBorders();//获取边框&
$objBorderA5-&getTop()-&setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);//边框样式
$objBorderA5-&getTop()-&getColor()-&setARGB('FFFF0000');//顶部边框的颜色&
$objBorderA5-&getBottom()-&setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);&
$objBorderA5-&getLeft()-&setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);//左样式
$objBorderA5-&getRight()-&setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);//右样式
//设置单元格的填充色
$objFillA5&=&$objStyleA5-&getFill();//填充&
$objFillA5-&setFillType(PHPExcel_Style_Fill::FILL_SOLID);//填充类型&
$objFillA5-&getStartColor()-&setARGB('FFEEEEEE');
//计算单元格的值
$objPHPExcel-&getActiveSheet()-&setCellValue('B7', '=SUM(B5:C5)');
$objPHPExcel-&getActiveSheet()-&getCell('B7')-&getCalculatedValue();
//如果要获取单元格的一个值,首先需要通过工作表的getCell方法获取到一个单元格对象,然后再通过单元格对象的getValue方法得到单元格的值,如果单元格的值是通过计算得到的,则需要使用getCalculatedValue方法获取单元格的值,设置单元格的值,我们只需要通过工作表的setCellValue方法来设置即可
//$dateTimeNow=time();
$objPHPExcel-&getActiveSheet()-&setCellValue('C10', PHPExcel_Shared_Date::PHPToExcel( $dateTimeNow ));//41105.75
$objPHPExcel-&getActiveSheet()-&getStyle('C10')-&getNumberFormat()-&setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_DATE_TIME4);//18:00:54,只是换了一种显示方式,并不会改变原来值的类型
echo gettype($objPHPExcel-&getActiveSheet()-&getCell('C10')-&getValue());//double
echo $objPHPExcel-&getActiveSheet()-&getCell('C10')-&getValue();//41105.75
//''一定要放在引号中,否则显示的值为,1979&&&&&&&&&&&&&& 文本(推荐)
$objPHPExcel-&setActiveSheetIndex(0)-&setCellValueExplicit(&D1&, '', PHPExcel_Cell_DataType::TYPE_STRING); //特征:字符串类型都是居左显示
//添加一个新的worksheet&
$objExcel-&createSheet();//创建一个新的工作表
$objExcel-&getSheet(1)-&setTitle('测试2');//设置当前工作表的标题
//保护单元格&
$objExcel-&getSheet(1)-&getProtection()-&setSheet(true);&
$objExcel-&getSheet(1)-&protectCells('A1:C22',&'PHPExcel');&&
//输出内容到excel文件,并将文件保存在服务器上
$objWriter-&save(&test.xls&);
//强制输出内容到浏览器下载&
header(&Content-Type:&application/force-download&);&
header(&Content-Type:&application/octet-stream&);&
header(&Content-Type:&application/download&);&
header('Content-Disposition:filename=&'.$outputFileName.'&');&
header(&Content-Transfer-Encoding:&binary&);&
header(&Expires:&Mon,&26&Jul&:00&GMT&);&
header(&Last-Modified:&&&.&gmdate(&D,&d&M&Y&H:i:s&)&.&&&GMT&);&
header(&Cache-Control:&must-revalidate,&post-check=0,&pre-check=0&);&
header(&Pragma:&no-cache&);&
$objWriter-&save('php://output');//参数-表示直接输出到浏览器,供客户端下载
//excel读取对象
$PHPReader = new PHPExcel_Reader_Excel5();//创建一个excel文件的读取对象
$PHPExcel = $PHPReader-&load($filePath);//读取一张excel表,返回excel文件对象
$currentSheet = $PHPExcel-&getSheet(0);//读取excel文件中的第一张工作表
$allColumn = $currentSheet-&getHighestColumn();//取得当前工作表最大的列号,如,E
$allRow = $currentSheet-&getHighestRow();//取得当前工作表一共有多少行
//设置工作簿默认的样式
$objPHPExcel-&getDefaultStyle()-&getFont()-&setName('Arial');
$objPHPExcel-&getDefaultStyle()-&getFont()-&setSize(8); &
//合并单元格
$objPHPExcel-&getActiveSheet()-&mergeCells('A18:E22');
案例1:使用迭代器循环所有的单元格;读取工作表中所有单元格的值,显示到一个table表格中
&& &&& &$objReader = PHPExcel_IOFactory::createReader('Excel2007');
&& &&& &$objReader-&setReadDataOnly(true);
&& &&& &$objPHPExcel = $objReader-&load(&test.xlsx&);
&& &&& &$objWorksheet = $objPHPExcel-&getActiveSheet();//获取当前活动工作表
&& &&& &echo '&table&' . &\n&;
&& &&& &foreach ($objWorksheet-&getRowIterator() as $row) {
&& &&& && echo '&tr&' . &\n&;& &
&& &&& && $cellIterator = $row-&getCellIterator();
&& &&& && $cellIterator-&setIterateOnlyExistingCells(false);
&& &&& && foreach ($cellIterator as $cell) {
&& &&& &&& &echo '&td&' . $cell-&getValue() . '&/td&' . &\n&;
&& &&& && }
&& &&& && echo '&/tr&' . &\n&;
&& &&& &echo '&/table&' . &\n&;
案例2:使用索引循环所有单元格
&& &&& &$objReader = PHPExcel_IOFactory::createReader('Excel2007');
&& &&& &$objReader-&setReadDataOnly(true); &
&& &&& &$objPHPExcel = $objReader-&load(&test.xlsx&);
&& &&& &$objWorksheet = $objPHPExcel-&getActiveSheet();
&& &&& &$highestRow = $objWorksheet-&getHighestRow(); // e.g. 10
&& &&& &$highestColumn = $objWorksheet-&getHighestColumn(); // e.g 'F'
&& &&& &$highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn); // 5
&& &&& &echo '&table&'.&\n&;
&& &&& &for ($row = 1; $row &= $highestR ++$row) {
&& &&& && echo '&tr&' . &\n&;
&& &&& && for ($col = 0; $col &= $highestColumnI ++$col) {
&& &&& &&& &echo '&td&' . $objWorksheet-&getCellByColumnAndRow($col, $row)-&getValue().'&/td&'.&\n&;
&& &&& && }
&& &&& && echo '&/tr&'.&\n&;
&& &&& &echo '&/table&'.&\n&;
注意:肯能后边会学到一个维度类(Dimensions),其实维度指的就是长*宽
版权声明:本文为博主原创文章,未经博主允许不得转载。
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:860968次
积分:12563
积分:12563
排名:第485名
原创:378篇
转载:257篇
评论:250条
(17)(2)(2)(1)(7)(8)(3)(21)(32)(38)(6)(5)(13)(11)(25)(1)(18)(2)(1)(11)(30)(8)(10)(12)(73)(114)(67)(74)(23)(1)访问本页面,您的浏览器需要支持JavaScript

我要回帖

更多关于 excel数值转换成文本 的文章

 

随机推荐