首页 后端开发 php教程 施用PHPExcel判别和格式化Excel中的日期格式

施用PHPExcel判别和格式化Excel中的日期格式

Jun 13, 2016 am 11:03 AM
cell gt phpexcel

  使用PHPExcel判别和格式化Excel中的日期格式
     最近,在做一个导入功能,在系统中使用PHPExcel类库,读取上传的Excel文件,然后进行字段映射,最后将Excel内的数据导入到系统中。其中,关于日期格式的导入,使我犯了难。
  首先,如何导入日期,因为PHPExcel中日期格式在获取时得到的是数字,并不是日期字符串,于是,网上就有许多代码,用于将Excel中获取的数字转换成PHP使用的Unix Time,其实不必这么麻烦。PHPExcel中就有这样的方法:PHPExcel_Shared_Date::ExcelToPHP($value) 。可以直接使用。
   如果到这里就结束,那这篇文章就有点太没意思了,在开发时,我还未一个问题犯了难,那就是如何自动判别Excel单元格是日期类型,照例,我Google了一遍,没有很好的文章解决这个问题,于是我就自己看着PHPExcel文档和源码,一边摸索,终于被我找出了方法,废话不多说,我先将代码贴上:

 function Read_Excel_File2($file_name,&$result){  
        require_once 'include/PHPExcel/Classes/PHPExcel/IOFactory.php';  
        $result=null;  
        $objReader = PHPExcel_IOFactory::createReader('Excel5');  
    //    $objReader->setReadDataOnly(true);  
        try{  
            $objPHPExcel = $objReader->load($file_name);  
        }catch(Exception $e){}  
        if(!isset($objPHPExcel)) return "无法解析文件";  
        $allobjWorksheets = $objPHPExcel->getAllSheets();  
        foreach($allobjWorksheets as $objWorksheet){  
            $sheetname=$objWorksheet->getTitle();  
            $highestRow = $objWorksheet->getHighestRow(); // e.g. 10  
            $highestColumn = $objWorksheet->getHighestColumn();  
            $highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn);  
            for ($row = 1; $row <= $highestRow; ++$row) {  
                for ($col = 0; $col <= $highestColumnIndex; ++$col) {  
                    $cell =$objWorksheet->getCellByColumnAndRow($col, $row);  
                    $value=$cell->getValue();  
                    if($cell->getDataType()==PHPExcel_Cell_DataType::TYPE_NUMERIC){  
                        
$cellstyleformat=$cell->getParent()->getStyle( 
$cell->getCoordinate() )->getNumberFormat();  
                        $formatcode=$cellstyleformat->getFormatCode();  
                        if (preg_match(&#39;/^(\[\$[A-Z]*-[0-9A-F]*\])*[hmsdy]/i&#39;, $formatcode)) {  
                           $value=gmdate("Y-m-d", PHPExcel_Shared_Date::ExcelToPHP($value));  
                        }else{  
                            $value=PHPExcel_Style_NumberFormat::toFormattedString($value,$formatcode);  
                        }  
    //                    echo $value,$formatcode,&#39;<br>&#39;;  
                          
                    }  
                    $result[$sheetname][$row-1][$col]=$value;  
                }  
            }  
        }  
        return 0;  
    }
登录后复制

其中,关于日期判断的部分主要是以下部分:

$cell =$objWorksheet->getCellByColumnAndRow($col, $row);  
    $value=$cell->getValue();  
    if($cell->getDataType()==PHPExcel_Cell_DataType::TYPE_NUMERIC){  
           $cellstyleformat=$cell->getParent()->getStyle( $cell->getCoordinate() )->getNumberFormat();  
           $formatcode=$cellstyleformat->getFormatCode();  
           if (preg_match(&#39;/^(\[\$[A-Z]*-[0-9A-F]*\])*[hmsdy]/i&#39;, $formatcode)) {  
                 $value=gmdate("Y-m-d", PHPExcel_Shared_Date::ExcelToPHP($value));  
           }else{  
                 $value=PHPExcel_Style_NumberFormat::toFormattedString($value,$formatcode);  
           }  
}
登录后复制

顺便说一下我的PHPExcel版本是 1.7.2 

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

华为GT3 Pro和GT4的差异是什么? 华为GT3 Pro和GT4的差异是什么? Dec 29, 2023 pm 02:27 PM

许多用户在选择智能手表的时候都会选择的华为的品牌,其中华为GT3pro和GT4都是非常热门的选择,不少用户都很好奇华为GT3pro和GT4有什么区别,下面就就给大家介绍一下二者。华为GT3pro和GT4有什么区别一、外观GT4:46mm和41mm,材质是玻璃表镜+不锈钢机身+高分纤维后壳。GT3pro:46.6mm和42.9mm,材质是蓝宝石玻璃表镜+钛金属机身/陶瓷机身+陶瓷后壳二、健康GT4:采用最新的华为Truseen5.5+算法,结果会更加的精准。GT3pro:多了ECG心电图和血管及安

修复:截图工具在 Windows 11 中不起作用 修复:截图工具在 Windows 11 中不起作用 Aug 24, 2023 am 09:48 AM

为什么截图工具在Windows11上不起作用了解问题的根本原因有助于找到正确的解决方案。以下是截图工具可能无法正常工作的主要原因:对焦助手已打开:这可以防止截图工具打开。应用程序损坏:如果截图工具在启动时崩溃,则可能已损坏。过时的图形驱动程序:不兼容的驱动程序可能会干扰截图工具。来自其他应用程序的干扰:其他正在运行的应用程序可能与截图工具冲突。证书已过期:升级过程中的错误可能会导致此issu简单的解决方案这些适合大多数用户,不需要任何特殊的技术知识。1.更新窗口和Microsoft应用商店应用程

PHP开发:使用 PHPExcel 处理 Excel 文件 PHP开发:使用 PHPExcel 处理 Excel 文件 Jun 15, 2023 pm 03:45 PM

随着数字化时代的到来,数据已经成为了我们日常生活和工作中最重要的一部分,而Excel文件则成为数据处理的重要工具之一。相信很多PHP开发者也会在工作中经常遇到使用Excel文件进行数据处理和操作的情况。本文将为大家介绍使用PHPExcel库来处理Excel文件的方法和注意事项。什么是PHPExcel?PHPExcel是一个PHP类

完全指南:如何使用php扩展PHPExcel处理Excel文件 完全指南:如何使用php扩展PHPExcel处理Excel文件 Jul 28, 2023 pm 10:01 PM

完全指南:如何使用PHP扩展PHPExcel处理Excel文件引言:在处理大量数据和统计分析时,Excel文件经常被用作数据存储和交换的一种常见格式。使用PHP扩展PHPExcel,我们可以轻松地读取、写入和修改Excel文件,从而有效地处理Excel数据。本文将介绍如何使用PHP扩展PHPExcel来处理Excel文件,并提供代码示例。一、安装PHPExc

如何修复无法连接到iPhone上的App Store错误 如何修复无法连接到iPhone上的App Store错误 Jul 29, 2023 am 08:22 AM

第1部分:初始故障排除步骤检查苹果的系统状态:在深入研究复杂的解决方案之前,让我们从基础知识开始。问题可能不在于您的设备;苹果的服务器可能会关闭。访问Apple的系统状态页面,查看AppStore是否正常工作。如果有问题,您所能做的就是等待Apple修复它。检查您的互联网连接:确保您拥有稳定的互联网连接,因为“无法连接到AppStore”问题有时可归因于连接不良。尝试在Wi-Fi和移动数据之间切换或重置网络设置(“常规”>“重置”>“重置网络设置”>设置)。更新您的iOS版本:

php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 Jun 13, 2016 am 10:23 AM

php提交表单通过后,弹出的对话框怎样在当前页弹出php提交表单通过后,弹出的对话框怎样在当前页弹出而不是在空白页弹出?想实现这样的效果:而不是空白页弹出:------解决方案--------------------如果你的验证用PHP在后端,那么就用Ajax;仅供参考:HTML code

怎么用phpexcel将Excel文件转成CSV文件并打开 怎么用phpexcel将Excel文件转成CSV文件并打开 Mar 27, 2023 pm 04:16 PM

​PHPEXCEL是一个优秀的PHP读写Excel文件的类库,它提供了非常充分的API,能够让我们使用PHP来读写Excel文件。而有些时候,我们需要将Excel文件转换成CSV文件,在一些场合下使用。那么,本文主要讲述如何使用PHPEXCEL类库将Excel文件转换成CSV文件,并进行打开。

特斯拉 Model Y、Model 3 电池组漏洞规避 IRA 税收激励规则,导致美国价格保持较低水平 特斯拉 Model Y、Model 3 电池组漏洞规避 IRA 税收激励规则,导致美国价格保持较低水平 Jun 26, 2024 pm 06:32 PM

最近有消息称,由于电池供电开关,特斯拉 Model 3 LR AWD 重新获得了 7,500 美元的全额税收优惠,正式使其与 Model Y 保持一致。Sawyer Merritt 最近在 X 上发表的一篇文章(来自 Autoevol)

See all articles