脚本宝典收集整理的这篇文章主要介绍了无法使用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()函数.但它不起作用或可能被错误地使用.我正在为这个项目设置一个紧迫的截止日期,所以如果有人能指出我正确的方向,那就太棒了.如果答案非常明显,真的很抱歉.非常感谢提前.
拉胡尔
但是,我不确定我到底是什么意思“随机乱码”…数字应该仍然显示为数字……请你举个例子.
编辑
请注意,getFormattedValue()等单元格方法将返回数字,因为它们是工作簿中屏蔽的格式,因此日期/时间值将被格式化为日期/时间,数字将显示相应的小数位数,千位分隔符或货币或百分比(如果它们在Excel文件中具有适当的格式),因此您不需要测试isDateTime()….只要没有为读取器设置$objReader-> setReadDataOnly(true).
以上是脚本宝典为你收集整理的无法使用PHPExcel正确显示日期,时间和数字全部内容,希望文章能够帮你解决无法使用PHPExcel正确显示日期,时间和数字所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。