无法使用PHPExcel正确显示日期,时间和数字
发布时间:2020-12-13 17:10:10 所属栏目:PHP教程 来源:网络整理
导读:这是我在stackoverflow中的第一个问题.我正在尝试使用 PHPExcel从.xlsx文件创建HTML表.你可以找到我的项目: http://rahulr92.x10.mx/excel/index.php 使用用户名“admin”登录,您会找到“查看表格”的选项.该页面显示先前上载的.xlsx文件中的表格.我是PHPEx
这是我在stackoverflow中的第一个问题.我正在尝试使用
PHPExcel从.xlsx文件创建HTML表.你可以找到我的项目:
http://rahulr92.x10.mx/excel/index.php 使用用户名“admin”登录,您会找到“查看表格”的选项.该页面显示先前上载的.xlsx文件中的表格.我是PHPExcel的新手,并使用了我在网上找到的一些标准代码.这里是: <?php require_once '/Classes/PHPExcel.php'; $objReader = PHPExcel_IOFactory::createReader('Excel2007'); $objReader->setReadDataOnly(true); $objPHPExcel = $objReader->load("..excel.xlsx"); $objWorksheet = $objPHPExcel->getActiveSheet(); $highestRow = $objWorksheet->getHighestRow(); $highestColumn = $objWorksheet->getHighestColumn(); $highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn); $user=strtolower($_GET['user']); $r_count=0; echo '<table border="1">' . "n"; for ($row = 5; $row <= $highestRow; ++$row) { if ($row <7 || $user=="admin" || strstr(strtolower($objWorksheet->getCellByColumnAndRow(8,$row)->getValue()),$user )) { if($row>7)$r_count++; for ($col = 0; $col <= $highestColumnIndex; ++$col) { if(PHPExcel_Shared_Date::isDateTime($objWorksheet->getCellByColumnAndRow($col,$row))) echo '<td>' . date("d M Y",PHPExcel_Shared_Date::ExcelToPHP($objWorksheet->getCellByColumnAndRow($col,$row))) . '</td>' ; else echo '<td>' . $objWorksheet->getCellByColumnAndRow($col,$row)->getValue() . '</td>' . "n"; } echo '</tr>' . "n"; } } echo '</table>' . "n"; echo "No. of Entries: ".$r_count; ?> 抱歉,次优代码.当我运行php文件时,我得到一个表,其中的所有字符串都正确显示,但是datetime和number字段充满了看似随机的乱码.请从上面的链接看一下.我做了一些研究,然后发现了isDateTime()函数.但它不起作用或可能被错误地使用.我正在为这个项目设置一个紧迫的截止日期,所以如果有人能指出我正确的方向,那就太棒了.如果答案非常明显,真的很抱歉.非常感谢提前. 解决方法
不要设置$objReader-> setReadDataOnly(true);如果您希望能够识别日期/时间值… Excel将日期/时间存储为浮点数,并且区分数字与日期/时间的唯一方法是使用格式掩码:isDateTime()使用该格式屏蔽以识别值是数字还是日期/时间… $objReader-> setReadDataOnly(true)告诉文件读取器只读取数据(数字)并忽略格式掩码,因此它只读取原始数据.
但是,我不确定我到底是什么意思“随机乱码”…数字应该仍然显示为数字……请你举个例子. 编辑 请注意,getFormattedValue()等单元格方法将返回数字,因为它们是工作簿中屏蔽的格式,因此日期/时间值将被格式化为日期/时间,数字将显示相应的小数位数,千位分隔符或货币或百分比(如果它们在Excel文件中具有适当的格式),因此您不需要测试isDateTime()….只要没有为读取器设置$objReader-> setReadDataOnly(true). (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |