PHP中使用ExcelReader读取EXCEL日期字段的处理

在使用PHP的ExcelReader扩展从EXCEL导入数据时,遇到时区和格式问题。日期通常以'd/m/Y'格式读取,而MySQL期望'Y-m-d'格式。可以通过修改reader.php文件进行转换,解决格式不匹配问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ExcelReader是个简单易用的东东,相信很多使用PHP的同学们需要从EXCEL中导入数据到数据库时,十有八九都会使用它,因为他实在是简单易用,看看他的例子就知道了。

 

不过从EXCEL中导入日期类型的字段的时候,问题就来了,首先是时区的问题,还有格式的问题。从EXCEL中读出的都是“d/m/Y”的格式,MYSQL中我一般都用“Y-m-d”的格式。转换格式比较容易,修改 /Spreadsheet_Excel_Reader/Excel/reader.php中的

 

var $dateFormats = array (
        0xe => "d/m/Y",
        0xf => "d-M-Y",
        0x10 => "d-M",
        0x11 => "M-Y",
        0x12 => "h:i a",
        0x13 => "h:i:s a",
        0x14 => "H:i",
        0x15 => "H:i:s",
        0x16 => "d/m/Y H:i",
        0x2d => "i:s",
        0x2e => "H:i:s",
        0x2f => "i:s.S");*/
修改为
var $dateFormats = array (
        0xe => "Y-m-d",
        0xf => "Y-M-d",
        0x10 => "M-d",
        0x11 => "Y-M",
        0x12 => "h:i a",
        0x13 => "h:i:s a",
        0x14 => "H:i",
        0x15 => "H:i:s",
        0x16 => "Y-m-d H:i",
        0x2d => "i:s",
        0x2e => "H:i:s",
        0x2f => "i:s.S");

 

$ifile = $_GET['ifile'];
$upfile_type = strtolower(pathinfo($ifile, PATHINFO_EXTENSION));
if ($upfile_type != 'xls') {
 $mess = "{success:false, message:'您选择的文件类型不是有效的EXCEL文件!'}";
 $mess = iconv("gb2312","utf-8//IGNORE",$mess);
 echo $mess;
 return;
}

require_once '../ExcelReader/reader.php';

// ExcelFile($filename, $encoding);
$data = new Spreadsheet_Excel_Reader();
// Set output Encoding.
$data->setOutputEncoding('CP936');

$data->read($ifile);

error_reporting(E_ALL ^ E_NOTICE);

...

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值