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


Unable to display date, time and numbers properly using 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 文件时,我得到一个表格,其中的所有字符串都正确显示,但日期时间和数字字段充满了看似随机的乱码。请从上面的链接中查看它。我做了一些研究,并以这种方式发现了isDateTime((函数。但它不起作用或可能使用错误。这个项目的截止日期很紧,所以如果有人能为我指出正确的方向,那就太好了。如果答案非常明显,真的很抱歉。提前非常感谢。拉胡尔

如果您希望

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

但是,我不确定我是否完全理解您所说的"随机胡言乱语"是什么意思......数字仍应显示为数字...你能举个例子吗?

编辑

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