最近收到一个很奇葩的需求,要求上传excel员工工资表,表格表头不固定,导入后字段名为表头的拼音,每月导入一次,当月重复导入则覆盖现有的当月表头,并且可以按照在界面上按照月份筛选显示,我写的代码主要包含了几个稍微复杂的地方:

1、excel文件导入后表头汉字转拼音作为字段名

2、phpexcel类读取excel文件中如果列数超过26个(也就是超出A-Z的范围)

3、当月数据上传多次,最近一次会覆盖上一次的全部数据,并且字段重新建立

下面是我实现的代码,包含了phpexcel类,数据库类,上传类,这些类文件可以网上找到,所以不再贴出来

 <?php
include_once("PHPExcel.php");//引入PHP EXCEL类
include_once("medoo.php");//引入数据库类
include_once("UploadFile.php");//引入上传类
define ('UPLOAD_PATH','./Uploads/');
$fieldArr = array('shenfenzhenghao', 'zhigongbianhao', 'gongjijinzhanghao', 'danwei', 'banzu', 'xingming'); if (isset($_FILES['excel']['size']) && $_FILES['excel']['size'] != null) {
$upload = new UploadFile();
$upload->maxSize = 10240000;
$upload->allowExts = array('xls');
$dirname = UPLOAD_PATH . date('Ym', time()).'/'.date('d', time()).'/';
if (!is_dir($dirname) && !mkdir($dirname, 0777, true)) {
echo '<script type="text/javascript">alert("目录没有写入权限!!");</script>';
}
$upload->savePath = $dirname;
$message = $upload->getErrorMsg();
if(!$upload->upload()) {
echo '<script type="text/javascript">alert("{$message}");</script>';
}else{
$info = $upload->getUploadFileInfo();
} if(is_array($info[0]) && !empty($info[0])){
$savePath = $dirname . $info[0]['savename'];
}else{
echo '<script type="text/javascript">alert("上传失败");</script>';
}; if(empty($savePath) or !file_exists($savePath)){die('file not exists');}
$PHPReader = new PHPExcel_Reader_Excel2007(); //建立reader对象
if(!$PHPReader->canRead($savePath)){
$PHPReader = new PHPExcel_Reader_Excel5();
if(!$PHPReader->canRead($savePath)){
echo 'no Excel';
return ;
}
}
$PHPExcel = $PHPReader->load($savePath); //建立excel对象
$currentSheet = $PHPExcel->getSheet(0); //**读取excel文件中的指定工作表*/
$allColumn = $currentSheet->getHighestColumn(); //**取得最大的列号*/
$allRow = $currentSheet->getHighestRow(); //**取得一共有多少行*/
$data = array();
$row = 1;
$rowOne = $rowArr = $main = $time = array();
$i = 0;
// 取出excel第一行全部字段
while(stringFromColumnIndex($i) != $allColumn) {
$addr = stringFromColumnIndex($i) . $row;
$cell = (String)$currentSheet->getCell($addr)->getValue();
if($cell instanceof PHPExcel_RichText){ //富文本转换字符串
$cell = $cell->__toString();
}
$rowOne[$row][stringFromColumnIndex($i)] = $cell;
$i++;
}
$cell = (String)$currentSheet->getCell($allColumn . $row)->getValue();
$rowOne[$row][$allColumn] = $cell; $newArr = array();
foreach($rowOne[1] as $key => $value) {
$tmp = Pinyin($value,'utf-8');
if(!in_array($tmp, $fieldArr)) {
$newArr[$key] = $tmp;
}
}
$db = new medoo(array(
'database_type' => 'mysql',
'database_name' => 'gzoa',
'server' => '127.0.0.1',
'username' => 'root',
'password' => '',
'port' => 3306,
'charset' => 'utf8',
'option' => array(PDO::ATTR_CASE => PDO::CASE_NATURAL)
)); $time = date("Ym", time());
$result = $db->select("fields", ["field_id","field","name"], ["time[=]" => $time]);
if(!empty($result)) {
$db->query("delete from fields where time = {$time}");
}
foreach($newArr as $key => $value) {
$insertData = array(
'is_main' => 0,
'field' => $value,
'name' => $rowOne[1][$key],
'form_type' => 'number',
'time' => $time
);
$db->insert("fields", $insertData);
} $infoArr = array();
foreach($newArr as $key => $value) {
foreach($rowOne[1] as $list => $content) {
if($key == $list) {
$infoArr[$value] = $content;
}
}
}
$infoSql = '';
foreach($infoArr as $key => $value) {
if(!empty($value)) {
$infoSql .= "`{$key}` float(25,2) NOT NULL COMMENT '{$value}',";
}
}
$infoSql = rtrim($infoSql, ','); $db->query("DROP TABLE `info_{$time}`"); $db->query("CREATE TABLE IF NOT EXISTS `info_{$time}` (
`userid` int(10) unsigned NOT NULL COMMENT '用户id',
`groupid` int(10) unsigned NOT NULL COMMENT '用户分组id', {$infoSql}
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1;"); $field_list = $db->select("fields", ["field_id","field","name"], ["OR" => ["is_main[=]" => 1,"time[=]" => $time]]);
foreach($field_list as $key => $value) {
foreach($rowOne[1] as $list => $content) {
if($content == $value['name']) {
$rowArr[$list] = $value['field'];
}
}
} $db->query("delete from info where time = {$time}");
for($rowIndex=2;$rowIndex<=$allRow;$rowIndex++){ //循环读取每个单元格的内容。注意行从1开始,列从A开始 $i = 0;
// 取出excel第一行全部字段
while(stringFromColumnIndex($i) != $allColumn) {
$colnum = stringFromColumnIndex($i);
$addr = stringFromColumnIndex($i) . $rowIndex;
$cell = (String)$currentSheet->getCell($addr)->getValue();
if($cell instanceof PHPExcel_RichText){ //富文本转换字符串
$cell = $cell->__toString();
}
if(!empty($cell)) {
if(in_array($rowArr[$colnum], $fieldArr)) {
$data1[$rowArr[$colnum]] = $cell;
} else {
$data2[$rowArr[$colnum]] = $cell;
}
}
$i++;
}
$cell = (String)$currentSheet->getCell($allColumn . $allRow)->getValue();
if(!empty($cell)) {
if(in_array($rowArr[$allColumn], $fieldArr)) {
$data1[$rowArr[$allColumn]] = $cell;
} else {
$data2[$rowArr[$allColumn]] = $cell;
}
} $data1['time'] = $time;
$data1['groupid'] = $data2['groupid'] = 0;//设置信息分组id
$name = isset($data1['xingming']) ? $data1['xingming'] : '';//判断如果帐号不存在,则创建帐号,默认密码123456
$result = $db->select("admin", ["id","uid","username"], ["username[=]" => $name]);
if(empty($result)) {
$adminData = array(
'uid' => 3,
'username' => $name,
'password' => md5('123456')
);
$db->insert("admin", $adminData);
}
$userid = $db->insert("info", $data1);
if($userid) {
$data2['userid'] = $userid;
$last_user_id = $db->insert("info_{$time}", $data2);
}
}
echo "<script language=javascript>" .
"alert('上传成功!'),parent.location.href='../main.php' " .
"</script>";
} function stringFromColumnIndex($pColumnIndex = 0)
{
static $_indexCache = array(); if (!isset($_indexCache[$pColumnIndex])) {
if ($pColumnIndex < 26) {
$_indexCache[$pColumnIndex] = chr(65 + $pColumnIndex);
} elseif ($pColumnIndex < 702) {
$_indexCache[$pColumnIndex] = chr(64 + ($pColumnIndex / 26)) . chr(65 + $pColumnIndex % 26);
} else { //开源软件:phpfensi.com
$_indexCache[$pColumnIndex] = chr(64 + (($pColumnIndex - 26) / 676)) . chr(65 + ((($pColumnIndex - 26) % 676) / 26)) . chr(65 + $pColumnIndex % 26);
}
}
return $_indexCache[$pColumnIndex];
} ?>

php读取excel文件并导入数据库(表头任意设定)的更多相关文章

  1. java读取excel文件数据导入mysql数据库

    这是我来公司的第二周的一个小学习任务,下面是实现过程: 1.建立maven工程(方便管理jar包) 在pom.xml导入 jxl,mysql-connector 依赖 可以在maven仓库搜索 2.建 ...

  2. jsp上传excel文件并导入数据库

    1,excel文件的上传 需要借助jar包:commons-fileupload-1.2.1.jar以及commons-io-1.3.2.jar 前端的html文件 <form id=" ...

  3. java后端服务器读取excel将数据导入数据库

    使用的是easypoi,官网文档:http://easypoi.mydoc.io/ /** * 导入Excel文件 */ @PostMapping("/importTeacher" ...

  4. larave5.6 将Excel文件数据导入数据库代码实例

    <?php namespace App\Admin\Controllers; use App\AdminUser; use Illuminate\Http\Request; use Excel; ...

  5. Excel文件数据导入到后台保存倒数据库

    后台代码数据解析: 方法一: (简单点) import org.apache.poi.hssf.usermodel.HSSFCell;import org.apache.poi.hssf.usermo ...

  6. POI读取Excel数据保存到数据库,并反馈给用户处理信息(导入带模板的数据)

    今天遇到这么一个需求,将课程信息以Excel的形式导入数据库,并且课程编号再数据库中不能重复,也就是我们需要先读取Excel提取信息之后保存到数据库,并将处理的信息反馈给用户.于是想到了POI读取文件 ...

  7. c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出

    c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出 using NPOI.HSSF.UserModel;using NPOI.SS.UserModel;using S ...

  8. springMVC(5)---导入excel文件数据到数据库

    springMVC(5)---导入excel文件数据到数据库 上一篇文章写了从数据库导出数据到excel文件,这篇文章悄悄相反,写的是导入excel文件数据到数据库.上一篇链接:springMVC(4 ...

  9. 项目一:第四天 1、快递员的条件分页查询-noSession,条件查询 2、快递员删除(逻辑删除) 3、基于Apache POI实现批量导入区域数据 a)Jquery OCUpload上传文件插件使用 b)Apache POI读取excel文件数据

    1. 快递员的条件分页查询-noSession,条件查询 2. 快递员删除(逻辑删除) 3. 基于Apache POI实现批量导入区域数据 a) Jquery OCUpload上传文件插件使用 b) ...

随机推荐

  1. Java面试之基础篇(5)

    41.a.hashCode() 有什么用?与 a.equals(b) 有什么关系?        hashCode() 方法对应对象整型的 hash 值.它常用于基于 hash 的集合类,如 Hash ...

  2. Swiper 的引入

    1. 从官网下载必要资源 https://www.swiper.com.cn/download/index.html#file1 2. 在项目中<head>中引入swiper.min.cs ...

  3. Zabbix4.x安装部署

    zabbix监控的重要性就不用再赘述了.直接上干货. 1.环境背景: Linux:CentOS 7.x, Database:MySQL zabbix server 和 zabbix mysql 安装在 ...

  4. 11.Linux date命令的用法

    date命令常的日常应用   修改时间 date -s “2008/05/23 19:20″ 打包文件 tar zcvf log-$(date +$F).gz /home/admin/logs 同步阿 ...

  5. Django 的 CBV&FBV

    Django FBV, function base view  视图里使用函数处理请求 url 1 url(r‘^users/‘, views.users), views 1 2 3 4 5 from ...

  6. vscode 代码缩进2格

    "editor.detectIndentation":false,

  7. string [线段树优化桶排]

    题意大概是给你一个字符串,1e5次修改,每次给一个区间升序排列或降序排列,最后输出这个字符串; 其实是个挺裸的线段树优化题;但是我没有意识去结合桶排,扑该..... 首先 1.40分算法 O(NMlo ...

  8. django操作cookie和session

    一.cookie:保存在客户端浏览器上的键值对 Cookie的由来 大家都知道HTTP协议是无状态的. 无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会 ...

  9. DVWA--XSS(DOM)

    0X01爱之先了解 DOM,全称Document Object Model,是一个平台和语言都中立的接口,可以使程序和脚本能够动态访问和更新文档的内容.结构以及样式. DOM型XSS其实是一种特殊类型 ...

  10. python基础之 数据格式化

    %还是format 皇城PK Python中格式化字符串目前有两种阵营:%和format,我们应该选择哪种呢? 自从Python2.6引入了format这个格式化字符串的方法之后,我认为%还是form ...