加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

无法使用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).

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读