基于yaf框架和uploadify插件,做的一个导入excel文件,查看并保存数据的功能

前端之家收集整理的这篇文章主要介绍了基于yaf框架和uploadify插件,做的一个导入excel文件,查看并保存数据的功能前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

思路:

1.首先,页面前端,上传附件,提交给后台,并带一个随机性的参数(可以用时间戳);

2.后端接收附件,做一系列的逻辑处理,无误后,将对应的文件存储在上传的目录下;

3.然后前端,上传附件成功后,进行请求后端,读取数据,后端接口对应将附件数据读取出来,前端进行显示(ajax请求);

4.前端展示数据,用户对数据检测无误,点击保存(ajax请求后端保存代码的接口),当然也可以有选择性的选择某些数据记录进行保存,楼主这里做的是全部保存(后端处理接口,自动过滤重复数据);

5.拿到对应的所需有用数据即可, 对应的excel表格,因为需要获取到人员排期数据,所以楼主是通过判断单元格的背景色来识别

代码如下:(关键代码

前端 对应html:





项目名称

对应js代码

上传excel文件!'); return false; } $.ajax({ url: '/lazy/CheckExcelColumns?type=save&guid=' + guid,type: 'get',dataType: 'json',success: function (data) { alert(data.msg); $('#close_window').click(); console.log('报存数据成功!'); },error:function(){ console.log('出错了!'); } }); } $(function(){ //导入层的js $("#import_schedule").bind('click',function(){ $("#gridImport_body").html(""); $("#import").modal("show"); }); //导入对应的函数 $('#file_upload').uploadify({ 'swf': '/public/uploadify/uploadify.swf',//FLash文件路径 'buttonText': '浏 览',//按钮文本 'uploader': '{{url("lazy/uploadExcel")}}',//后台处理程序的路径 'queueID': 'fileQueue',//队列的ID 'queueSizeLimit': 1,//队列最多可上传文件数量,默认为999 'auto': false,//选择文件后是否自动上传,默认为true 'multi': false,//是否为多选,默认为true 'removeCompleted': true,//是否完成后移除序列,默认为true 'fileSizeLimit': '10MB',//单个文件大小,0为无限制,可接受KB,MB,GB等单位的字符串值 'fileTypeDesc': 'Excel Files',//文件描述 'fileTypeExts': '*.xlsx',//上传文件后缀过滤器 'onQueueComplete': function (event,data) { //所有队列完成后事件 //业务处理代码 //提示用户Excel格式是否正常,如果正常加载数据 var guid = $("#AttachGUID").val(); $.ajax({ url: '/lazy/CheckExcelColumns?type=check&guid=' + guid,success: function (data) { if (data.status) { // InitGrid(); //重新刷新表格数据 $.each(data.rows,function (i,item) { var tr = "文件','guid': guid,'token':token,} ); },'onUploadError': function (event,queueId,fileObj,errorObj) { alert(errorObj.type + ":" + errorObj.info); } }); function InitUpFile(){ var timestamp = Date.parse(new Date()); $('#AttachGUID').val(timestamp); }

后端代码

PHP;"> //上传文件处理 public function uploadExcelAction() { $targetFolder = '/public/uploadFile/'; // Relative to the root      $salt = 'test'; $verifyToken = md5($test . $_POST['guid']); if (!empty($_FILES) && $_POST['token'] == $verifyToken) { $tempFile = $_FILES['Filedata']['tmp_name']; $targetPath = $_SERVER['DOCUMENT_ROOT'] . $targetFolder; $targetFile = rtrim($targetPath,'/') . '/' . $verifyToken.'.xlsx';

$fileTypes = array('xlsx');
$fileParts = pathinfo($_FILES['Filedata']['name']);
if (in_array($fileParts['extension'],$fileTypes)) {
move_uploaded_file($tempFile,$targetFile);
echo '1';
} else {
echo 'Invalid file type.';
}
}else{
echo 'Invalid params.';
}
die;
}

处理excel数据,就说两个关键点:取单元格的值和背景色

load($targetFile); $sheet = $objPHPExcel->getSheet(); $sheetRows = $sheet->getHighestDataRow(); // 取得总行数 $sheetColumns = PHPExcel_Cell::columnIndexFromString($sheet->getHighestDataColumn()); //列数

//读取单元格
$value = $objPHPExcel->getActiveSheet()->getCell($columns[$k] . $j)->getValue(); //获取每个单元格的值
$fillColor = $objPHPExcel->getActiveSheet()->getStyle($columns[$k] . $j)->getFill()->getStartColor()->getARGB(); //背景色

下面附图:

导入界面:

excel表:

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持编程之家!

猜你在找的PHP相关文章

项目编号 功 能 人 员 日 期