热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

PHP导入Excel考勤表

PHP导入Excel考勤表安装PHPExcel引入IOFactory.php考勤表如下上传,接收,移动Excel文件加载文件获取Excel中想要的数据然后把得到的数据放入数据库中进

PHP导入Excel考勤表

  • 安装PHPExcel
    • 引入IOFactory.php
    • 考勤表如下
    • 上传,接收,移动 Excel文件
    • 加载文件
    • 获取Excel中想要的数据
      • 然后把得到的数据放入数据库中进行后续操作;


安装PHPExcel

使用composer安装:

composer require phpoffice/phpexcel

引入IOFactory.php

require_once(ROOT_PATH . 'vendor/phpoffice/phpexcel/Classes/PHPExcel/IOFactory.php');

考勤表如下

Excel考勤表:
在这里插入图片描述


上传,接收,移动 Excel文件

<div class="layui-form-item" style="width: 99%"><form action="{:url('index/Attesgerbdfb/attendancsdfsscel_in')}" enctype="multipart/form-data" method="post"><input type="file" name="excel" /><span>覆盖&nbsp;</span><input type="checkbox" value="1" name="yes" id="yes" checked><span>&nbsp;&nbsp;不覆盖&nbsp;</span><input type="checkbox" value="2" name="no" id="no"><input type="submit" value="上传" /></form></div>

$file = request()->file('excel');
ini_set('max_execution_time', '0');
$info = $file->move(ROOT_PATH . 'public' . DS . 'upload'.DS.'excel');
// 成功上传后 获取上传信息
$path = $info->getSaveName();// 获取文件保存路径
$extension = $info->getExtension();
if( $extension =='xlsx' )
{
$objReader = PHPExcel_IOFactory::createReader('Excel2007');
}else{
$objReader = PHPExcel_IOFactory::createReader('Excel5');
}

加载文件

//加载excel文件
$filename = ROOT_PATH . 'public' . DS . 'upload'.DS.'excel'.DS.$path;$objReader ->setReadDataOnly(true); //只读取数据,忽略所有空白行$objPHPExcel = $objReader->load($filename);//获取excel文件$sheetCount = $objPHPExcel->getSheetCount();// 获取工作表的数目;

获取Excel中想要的数据

// 组装获取单张sheet考勤数据的三个数组;
$one = array('A','B','D','G','I','K','M');
$two = array('P','Q','S','V','X','Z','AB');
$three = array('AE','AF','AH','AK','AM','AO','AQ');
//TODO sheet需要超过两个~
$arr = array();
$brr = array();
$crr = array();
for($i=2;$i<$sheetCount;$i++){
//不需要最后两张表;
$sheet = $objPHPExcel->getSheet($i); //激活当前的表
$highestRow = $sheet->getHighestRow(); // 取得总行数
$highestColumn = $sheet->getHighestColumn(); // 取得总列数// 此sheet的人名 部门 日期
$arr[$i]['depart'] = $sheet->getCell("B4")->getValue();
$arr[$i]['username'] = $sheet->getCell("J4")->getValue();
$arr[$i]['date'] = $sheet->getCell("B5")->getValue();
$brr[$i]['depart'] = $sheet->getCell("Q4")->getValue();
$brr[$i]['username'] = $sheet->getCell("Y4")->getValue();
$brr[$i]['date'] = $sheet->getCell("Q5")->getValue();
$crr[$i]['depart'] = $sheet->getCell("AF4")->getValue();
$crr[$i]['username'] = $sheet->getCell("AN4")->getValue();
$crr[$i]['date'] = $sheet->getCell("AF5")->getValue();// 此sheet的某个员工的考勤记录$drr = array();
$err = array();
$frr = array();
for($j=13;$j<=$highestRow;$j++)
{
//当前sheet第一个人的考勤记录
foreach ($one as $k_one=>$v_one){
$d = $sheet->getCell("A".$j)->getValue();if(empty($d)){break;}
$x = $sheet->getCell($v_one.$j)->getValue();
if(is_float($x)){
$drr[$j][$k_one] = gmdate('H:i',\PHPExcel_Shared_Date::ExcelToPHP($x));}else{
$drr[$j][$k_one] = $sheet->getCell($v_one.$j)->getValue();}}
//当前sheet第二个人的考勤记录
foreach ($two as $k_two=>$v_two){$e = $sheet->getCell("P".$j)->getValue();if(empty($e)){break;}$y = $sheet->getCell($v_two.$j)->getValue();if(is_float($y)){
$err[$j][$k_two] = gmdate('H:i',\PHPExcel_Shared_Date::ExcelToPHP($y));}else{$err[$j][$k_two] = $sheet->getCell($v_two.$j)->getValue();}}//当前sheet第三个人的考勤记录foreach ($three as $k_three=>$v_three){
$f = $sheet->getCell("AE".$j)->getValue();if(empty($f)){break;}
$z = $sheet->getCell($v_three.$j)->getValue();
if(is_float($z)){
$frr[$j][$k_three] = gmdate('H:i',\PHPExcel_Shared_Date::ExcelToPHP($z));}else{
$frr[$j][$k_three] = $sheet->getCell($v_three.$j)->getValue();}}}$arr[$i]['attend'] = $drr;$brr[$i]['attend'] = $err;$crr[$i]['attend'] = $frr;}
// $arr $brr $crr 整合数组
$zrr = array_merge($arr,$brr,$crr);

然后把得到的数据放入数据库中进行后续操作;


推荐阅读
  • JavaWeb中读取文件资源的路径问题及解决方法
    在JavaWeb开发中,读取文件资源的路径是一个常见的问题。本文介绍了使用绝对路径和相对路径两种方法来解决这个问题,并给出了相应的代码示例。同时,还讨论了使用绝对路径的优缺点,以及如何正确使用相对路径来读取文件。通过本文的学习,读者可以掌握在JavaWeb中正确找到和读取文件资源的方法。 ... [详细]
  • PDO MySQL
    PDOMySQL如果文章有成千上万篇,该怎样保存?数据保存有多种方式,比如单机文件、单机数据库(SQLite)、网络数据库(MySQL、MariaDB)等等。根据项目来选择,做We ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • springmvc学习笔记(十):控制器业务方法中通过注解实现封装Javabean接收表单提交的数据
    本文介绍了在springmvc学习笔记系列的第十篇中,控制器的业务方法中如何通过注解实现封装Javabean来接收表单提交的数据。同时还讨论了当有多个注册表单且字段完全相同时,如何将其交给同一个控制器处理。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 本文介绍了django中视图函数的使用方法,包括如何接收Web请求并返回Web响应,以及如何处理GET请求和POST请求。同时还介绍了urls.py和views.py文件的配置方式。 ... [详细]
  • Imtryingtofigureoutawaytogeneratetorrentfilesfromabucket,usingtheAWSSDKforGo.我正 ... [详细]
  • 本文讨论了在使用PHP cURL发送POST请求时,请求体在node.js中没有定义的问题。作者尝试了多种解决方案,但仍然无法解决该问题。同时提供了当前PHP代码示例。 ... [详细]
  • SpringBoot简单日志配置
     在生产环境中,只打印error级别的错误,在测试环境中,可以调成debugapplication.properties文件##默认使用logbacklogging.level.r ... [详细]
  • 有几百条数据类似*Oct1809:46:09:%NFPP_IP_GUARD-4-DOS_DETECTED:Host<IP60.12.174.45,MACNA,portGi2 ... [详细]
  • MySQL中的MVVC多版本并发控制机制的应用及实现
    本文介绍了MySQL中MVCC的应用及实现机制。MVCC是一种提高并发性能的技术,通过对事务内读取的内存进行处理,避免写操作堵塞读操作的并发问题。与其他数据库系统的MVCC实现机制不尽相同,MySQL的MVCC是在undolog中实现的。通过undolog可以找回数据的历史版本,提供给用户读取或在回滚时覆盖数据页上的数据。MySQL的大多数事务型存储引擎都实现了MVCC,但各自的实现机制有所不同。 ... [详细]
author-avatar
mobiledu2502918997
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有