gpt4 book ai didi

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

转载 作者:可可西里 更新时间:2023-10-31 23:09:10 27 4
gpt4 key购买 nike

这是我在 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 将日期/时间存储为 float ,而将数字与日期/时间区分开来的唯一方法是使用格式掩码:isDateTime() 使用该格式掩码来识别值是数字还是日期/时间... $objReader->setReadDataOnly(true) 告诉文件读取器只读取数据(数字)并忽略格式掩码,因此它只读取原始数据。

但是,我不确定我是否理解“随机乱码”的确切含义...数字仍应显示为数字...您能举个例子吗。

编辑

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

关于php - 无法使用 PHPExcel 正确显示日期、时间和数字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8626239/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com