无法使用PHPExcel正确显示日期,时间和数字

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了无法使用PHPExcel正确显示日期,时间和数字脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
这是我在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()函数.但它不起作用或可能被错误地使用.我正在为这个项目设置一个紧迫的截止日期,所以如果有人能指出我正确的方向,那就太棒了.如果答案非常明显,真的很抱歉.非常感谢提前.
拉胡尔

解决方法

@H_360_17@ 不要设置$objReader-> setReadDataOnly(true);如果您希望能够识别日期/时间值… Excel将日期/时间存储为浮点数,并且区分数字与日期/时间的唯一方法是使用格式掩码:isDateTime()使用该格式屏蔽以识别值是数字还是日期/时间… $objReader-> setReadDataOnly(true)告诉文件读取器只读取数据(数字)并忽略格式掩码,因此它只读取原始数据.

但是,我不确定我到底是什么意思随机乱码”…数字应该仍然显示为数字……请你举个例子.

编辑

请注意,getFormattedValue()等单元格方法将返回数字,因为它们是工作簿中屏蔽的格式,因此日期/时间值将被格式化为日期/时间,数字将显示相应的小数位数,千位分隔符或货币或百分比(如果它们在Excel文件中具有适当的格式),因此您不需要测试isDateTime()….只要没有为读取器设置$objReader-> setReadDataOnly(true).

脚本宝典总结

以上是脚本宝典为你收集整理的无法使用PHPExcel正确显示日期,时间和数字全部内容,希望文章能够帮你解决无法使用PHPExcel正确显示日期,时间和数字所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。