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

时间:2011-12-24 18:38:15

标签: php 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()函数。但它不起作用或可能被错误地使用。我正在为这个项目设置一个紧迫的截止日期,所以如果有人能指出我正确的方向,那就太棒了。如果答案非常明显,真的很抱歉。非常感谢提前。 拉胡

1 个答案:

答案 0 :(得分:4)

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

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

修改

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