excel批量导入数据

excel批量导入数据

这个功能也是我以前项目中经常用到的,感觉很实用,必须拿来分享下:

excel进行批量导入数据,结合struts2+ajax

导入的视图:batchAdd.ftl(视图无关紧要的,可以换成其他任何视图,就是普通的form表单的提交,就是这里是调用ajax)

复制代码
<div class="controltitle">当前操作:excel批量导入学生信息</div>
<div> 
<form action="excelUploadAction.action" method="post" enctype="multipart/form-data" id="uploadInfor"
        onSubmit="return validateuploadInforFile(this);">
            <input type="file" name="uploadExcel">
            <input type="submit" value="提交"/><a href = "download/stuExcel.xls">[点击下载excel样例]</a>
</form>
</div>
<div>
    <div>下面是导入的excel的样式<font color = "red">[上传的excel中的内容必须按照这个顺序就行排版,否则存储内容的位置会错乱的]</font></div>
    <table class="tablefirst" id="radioSubStyle">
        <tr>
            <th>姓名</th><th>学号</th><th>性别</th><th>籍贯</th><th>专业</th><th>学制</th><th>入学年份</th>
            <th>毕业年份</th><th>工作省市</th><th>工作单位</th><th>工作岗位</th><th>职务职称</th>
            <th>电话</th><th>手机</th><th>qq</th><th>邮箱</th><th>通信地址</th><th>家庭地址</th>
        </tr>
        <tr>
            <td>沈浪</td><td>1006010054</td><td>男</td><td>汉</td><td>眼7</td><td>7</td><td>2009-11-11</td>
            <td>2011-11-11</td><td>浙江</td><td>医院</td><td>临床</td><td>主任</td>
            <td>642</td><td>159</td><td>5449</td><td>544@qq.com</td><td>杭州</td><td>杭州</td>
        </tr>
        <tr>
            <td>沈浪</td><td>1006010024</td><td>男</td><td>汉</td><td>眼7</td><td>7</td><td>2009-11-11</td>
            <td>2011-11-11</td><td>浙江</td><td>医院</td><td>临床</td><td>主任</td>
            <td>642</td><td>159</td><td>5449</td><td>544@qq.com</td><td>杭州</td><td>杭州</td>
        </tr>
        <tr>
            <td>沈浪</td><td>1006010034</td><td>男</td><td>汉</td><td>眼7</td><td>7</td><td>2009-11-11</td>
            <td>2011-11-11</td><td>浙江</td><td>医院</td><td>临床</td><td>主任</td>
            <td>642</td><td>159</td><td>5449</td><td>544@qq.com</td><td>杭州</td><td>杭州</td>
        </tr>
    </table>
    <div><font color="red">注:①excel各列的顺序必须按样式的顺序,而内容可依实际内容而定;这里不支持照片的导入,照片可在修改中进行上传②性别只能为‘男’与‘女’;③专业只能填:眼视光七年制;眼视光本科;眼视光专科;否则会影响后面的查询</font></div>
</div>
<div id="excelUploadMsg"></div>
复制代码

传入的js(ajax+文件的验证):这里涉及到的ajax可以去阅读:http://www.cnblogs.com/shenliang123/archive/2012/04/16/2452670.html

复制代码
/**
 * 以下是上传excel的一系列方法
 * */
function validateuploadInforFile(form){
        if(!validateExcelUpLoadFile(form)) return false;
        var options = { 
            dataType: 'json',
            success: showResponse 
        };
        $("#uploadInfor").ajaxSubmit(options); 
        return false;
}

function showResponse(responseText){
  $("#excelUploadMsg").empty();
  $("#excelUploadMsg").append(responseText.msg);
  
}
//导入考试时进行文件格式校验
function validateExcelUpLoadFile(form) {
    var fileName = form.uploadExcel.value;
    
    if (fileName != "" ) {
        var fileType = (fileName.substring(fileName.lastIndexOf(".") + 1, fileName.length)).toLowerCase();
        var suppotFile = ["xls", "XLS", "xlsx", "XLSX"];
        for (var i = 0; i < suppotFile.length; i++) {
            if (suppotFile[i] == fileType) {
                return true;
            } else {
                continue;
            }
        }
        alert("文件格式不正确!");
        return false;
    } else {
        alert("请选择你需要的导入 的文件");
        return false;
    }
}
复制代码

struts.xml:

<!-- excel导入 -->
          <action name="excelUploadAction" class="xidian.sl.action.StuInforAction" method = "excelUpload">
              <interceptor-ref name="fileUpload"/>
              <interceptor-ref name="defaultStack" />
              <result name="success">/WEB-INF/responseMsg.jsp</result>
          </action>

action中的方法处理:再次进行文件的验证和调用服务层进行excel的处理和数据持久化

复制代码
//以下为单文件上传,即excel
    private File uploadExcel;                                                //文件
    private String uploadExcelFileName;                                        //文件名
    private static String[] allowFileType = { "xls", "XLS", "xlsx", "XLSX" };     //控制文件类型
    /**
     * excel批量导入
     * */
    public String excelUpload(){
        try{
            if ((uploadExcelFileName == null) || (uploadExcelFileName.equals(""))) {
                response = "{success:false,msg:'文件名不能为空!'}";
            }
            if (!(FileUtil.validateFileType(uploadExcelFileName, allowFileType))) {   //validateFileType方法在FileUtil中,返回的是boolean值
                response = "{success:false,msg:'文件类型不正确!'}";
            }
            excelBatchInput.uploadStu(uploadExcel);                                    //只传入一个excel文件
            response = "{success:true,msg:'"+excelBatchInput.getFinalMsg()+"'}";    //得到结果的回复
        }catch (Exception e) {
            e.printStackTrace();
            response = "{success:true,msg:'sorry: 导入失败'}";
        }
        return SUCCESS;
    }
复制代码

serviceInterface:

复制代码
package xidian.sl.service.admin;

import java.io.File;

public interface ExcelBatchInput {
    /**
     * excel导入的主要逻辑
     * */
    public String uploadStu(File upload);
    /**
     * 导入后的消息
     * */
    public String getFinalMsg();
}
复制代码

ServiceImpl:(这里对excel的内容没有做过多的验证,只是验证了学号为不重复,大家可以自行对其进行添加)

复制代码
package xidian.sl.service.impl.admin;

import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.List;

import jxl.Cell;
import jxl.CellType;
import jxl.DateCell;
import jxl.LabelCell;
import jxl.Sheet;
import jxl.Workbook;
import xidian.sl.dao.admin.StuInforDAO;
import xidian.sl.entity.StuInfor;
import xidian.sl.service.admin.ExcelBatchInput;

public class ExcelBatchInputImpl implements ExcelBatchInput {
    private Sheet sheet;
    private String[][] excelValue;
    private int successRow;
    private int failRow;
    private StringBuilder msg=new StringBuilder();
    private String finalMsg;
    private StuInforDAO stuInforDAO;
    /**
     * excel导入的总方法
     */
    public String uploadStu(File upload) {
        initExcel(upload);        //初始化
        readExcel();            //读取
        insertIntoDB();            //插入
        return msg.toString();
    }
    /**
     * 读取excel文件中数据,保存到sheet对象中
     * @param upload
     */
    private void initExcel(File upload) {
        Workbook rwb = null;
        try {
            InputStream is = new FileInputStream(upload);
            rwb = Workbook.getWorkbook(is);

            sheet = rwb.getSheet(0);
        }     catch (Exception e) {
            e.printStackTrace();
        }
    }
    /**
     * 读取excel中数据进入excelValue数组中
     */
    private void readExcel(){
        excelValue = new String[sheet.getRows()][sheet.getColumns()];
        for (int i = 0; i < sheet.getRows(); i++)
            for (int j = 0; j < sheet.getColumns(); j++) {
                Cell cell = sheet.getCell(j, i);
                if ("".equals(cell.getContents().toString().trim())){
                    excelValue[i][j] = "";
                }
                if (cell.getType() == CellType.LABEL) {
                    LabelCell labelcell = (LabelCell)cell;
                    excelValue[i][j] = labelcell.getString().trim();
                } else if (cell.getType() == CellType.NUMBER){
                    excelValue[i][j] = cell.getContents();
                } else if (cell.getType() == CellType.DATE) {
                    DateCell datcell = (DateCell)cell;
                    excelValue[i][j] = datcell.getDate().toString();
                } else {
                    excelValue[i][j] = cell.getContents().toString().trim();
                }
          }
      }
    
    /**
      * 3.保存进入数据库
      * @param course
      */
    private void insertIntoDB() {
        int excelRows = excelValue.length;
        //将消息清空
        msg.delete(0, msg.length());
        finalMsg = "";
        successRow = 0;
        failRow = 0;
        if (excelValue.length > 1) {
            for (int i = 1; i < excelRows; i++) {        //从第二排开始,第一排为文字说明
                String[] DBValue = excelValue[i];        //取一行数据
                if (validateInfor(i,DBValue)){
                    successRow += 1;
                    finalInsert(DBValue);
                } else {
                    failRow += 1;
                }
            }
                finalMsg = "录入成功结束:"+"</br>"+"目标导入学生:"+(successRow+failRow)+"</br>"
                +"成功录入数:"+(successRow)+"</br>"
                +"失败录入数:"+(failRow)+"</br>"
                +msg.toString();
            System.out.println(finalMsg);
        } else {
            finalMsg = "excel中无任何数据!";
            System.out.println("excel中没有任何数据");
        }
    }
    
    //最终返回检验结果
    private boolean validateInfor(int i,String[] DBValue){
        Boolean bol=true;
        if(!(validateNumRepeat(i,DBValue))){
            bol=false;
        }
        return bol;
    }
    
    //验证岗位是否重复
    private boolean validateNumRepeat(int i,String[] DBValue){
        boolean bolValidate=true;
        /**
         * 主要检查学号是否有重复
         * 这里需要改进,因为这里会每插入一条就会进行一次数据库的搜索
         * */
        String hql = "from StuInfor";
        List<StuInfor> stuInfors = stuInforDAO.getStuInforListByHQL(hql);
        for(StuInfor stuInfor: stuInfors){
            if(stuInfor.getStuNum().equals(DBValue[1]) && DBValue[1]!=""){
                bolValidate=false;
                msg.append("错误信息:第"+i+"学生的学号与数据库已存储的重复,该学号是["+DBValue[1]+"],导入的学生名字["+DBValue[0]+"],请检查!</br>");
                return bolValidate;
            }
        }
        return bolValidate;
    }
    
    
    //最终插入数据,这里需要修改
    private void finalInsert(String[] DBValue){
        StuInfor stuInfor = new StuInfor();
        stuInfor.setStuName(DBValue[0]);
        stuInfor.setStuNum(DBValue[1]);
        stuInfor.setStuSex(DBValue[2]);
        stuInfor.setStuJg(DBValue[3]);
        stuInfor.setStuZy(DBValue[4]);
        
        stuInfor.setStuXz(DBValue[5]);
        stuInfor.setStuStartTime(DBValue[6]);
        stuInfor.setStuEndTime(DBValue[7]);
        stuInfor.setStuWorkAddress(DBValue[8]);
        stuInfor.setStuWorkPlace(DBValue[9]);
        
        stuInfor.setStuWorkPost(DBValue[10]);
        stuInfor.setStuWorkZc(DBValue[11]);
        stuInfor.setStuPhone(DBValue[12]);
        stuInfor.setStuTelephone(DBValue[13]);
        stuInfor.setStuQq(DBValue[14]);
        
        stuInfor.setStuEmail(DBValue[15]);
        stuInfor.setStuCommAddress(DBValue[16]);
        stuInfor.setStuAddress(DBValue[17]);
        stuInfor.setDeleteSign("1");
        stuInforDAO.makePersistence(stuInfor);
    }
    public Sheet getSheet() {
        return sheet;
    }
    public void setSheet(Sheet sheet) {
        this.sheet = sheet;
    }
    public String[][] getExcelValue() {
        return excelValue;
    }
    public void setExcelValue(String[][] excelValue) {
        this.excelValue = excelValue;
    }
    public int getSuccessRow() {
        return successRow;
    }
    public void setSuccessRow(int successRow) {
        this.successRow = successRow;
    }
    public int getFailRow() {
        return failRow;
    }
    public void setFailRow(int failRow) {
        this.failRow = failRow;
    }
    public StringBuilder getMsg() {
        return msg;
    }
    public void setMsg(StringBuilder msg) {
        this.msg = msg;
    }
    public String getFinalMsg() {
        return finalMsg;
    }
    public void setFinalMsg(String finalMsg) {
        this.finalMsg = finalMsg;
    }

    public StuInforDAO getStuInforDAO() {
        return stuInforDAO;
    }
    public void setStuInforDAO(StuInforDAO stuInforDAO) {
        this.stuInforDAO = stuInforDAO;
    }
}
一、特色 本作品采用EXCEL 公式+VBA制作,既可根据你平时使用EXCEL的习惯和方式操作充分发挥EXCEL的功能,又能利用本作品提高效率。 ※※※※二、主要功能 1、在原始成绩表自动按你要求的统计科目生成总分、平均分、班级排名、年级排名等。 2、查询:查询条件多样,可按姓名查询、按班级查询(分班);按某学科(含总分)某分数段查询;按班内名次(年级名次)段查询(如某班前XX名、年级前XX-XX名)等,各种查询条件还可自由组合。对查询结果,可按某关键字排序后显示,如按班级排名升序可组合出某班全部或班前XX名、年级前XX名排名等,按年级排名升序可组合出年级前XX名排名或全部排名等。 3、统计:根据班级和科目(含总体)按统计范围自动实时生成各项指标(参考人数、平均分、及格人数、及格率、优生人数、优生率、差生人数、差生率等)、各分数段人数统计、年级前XX名在各班分布等。 4、成绩册和成绩条:实时自动按班生成成绩册和成绩条。 ※※※※三、操作指南   第一步:在总表输入、导入、复制粘贴或在记录单逐条录入原始成绩(第一行为如下形式) 学号 ∣ 数学 ∣ 总分 ∣ 学号 ∣ 语文 ∣ 班级 ∣ 英语 ∣ 姓名 ∣ 政治 ∣ 历史 ∣ 物理 ∣ 化学 ∣ …… "  1、其各列位置不固定   2、班级列必须包含   3、可以任意增加删除科目   4、可以任意增加删除辅助列如:学号、年级、座位号等"   第二步 :设置 "  1、打开设置工作表进行设置   2、包括考试名称和统计科目的设置   3、具体设置方法表内的批注已经说明"   第三步:点击控制条上的各个按钮进行相应统计 其,分班成绩册和成绩单、统计分别以VBA和公式两种方式制作,这两种方式各有特点,供你选择:公式方式的优点是当条件变化(如所选班级、科目变化)时显示结果随之实时变化,除非公式被破坏或者刚从其它表册转入本功能你才需要重新点击按钮;VBA方式每次改变条件后必须点击相应按钮才能刷新结果,但对结果你可随意进行各种操作。如果你觉得窗体有可能遮住结果,窗体可移动,可关闭,以便在EXCEL按你熟悉的方式操作。另总表还提供了按班级排序、填入总分、平均分、计算班级排名、年级排名、分数超限检查等多种自动化功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值