您的位置:首页 > 编程语言 > Java开发

[置顶] 如何在Java中导入Excel表数据

2017-05-08 11:02 701 查看
前期准备和申明:

    1.之前自己在做这个Excel导入的时候也看了网上的一些博客,jxl很容易存在.xls 和.xlsx格式判断的问题。所以我选择POI,自己可以去网上下载,下载地址:http://poi.apache.org/download.html

    2.Excel数据模型准备好

开始:

   jsp和js中的代码自己写哈,因为我们用的前段框架可能不同,所以写出来也没有用,如果用ace框架的倒是可以私信我要代码,我这里只展示一下效果图


在Java后台中

  首先我们如何在后台获取到你上传的Excel的文件类型和名称呢?在你的action中定义这个几个变量,我是在公司封装的框架下的某个层。但道理一样,如下:

    private File     uploadexcel;                    //文件(和jsp中的名字保持一致)

    private String uploadexcelFileName;            //文件名称

    private String uploadexcelContentType;        //文件类型

值得注意的是,在你的jsp中<input >标签中文件的名字必须是uploadexcel,例如<input id="importFile" type="file" data-options="required:false"

                        name="dto.uploadexcel" />

然后是在后台的上传的方法,我这里会贴出与代码中相关的方法,但不会把封装的公共类拿出来,望见谅。

public void uploadexcle(BaseAbstractDto basedto) throws Exception{        

        MemberDto dto=super.getExactlyDto(basedto);     //公司封装的参数传输层,按你们的框架自行修改  

        File uploadexcle =dto.getUploadexcel();                //获取上传的Excel表格文件

        List<Member> list = new ArrayList<Member>();

            String filetype =UploadFileUtil.getFileExp(dto.getUploadexcelFileName());    //这个方法我会在名为方法一的下面贴出来

            Workbook workbook=null;                                    //POI中的

            if(filetype.equals(".xls")||filetype.equals(".xlsx")){

                if (uploadexcle!=null&&uploadexcle.length()>0) {                                        

                    workbook=UploadFileUtil.getWorkbook(uploadexcle);                //这个方法我会在名为方法二的下面贴出来           

                Sheet sheet=UploadFileUtil.deleteNullRow(workbook.getSheetAt(0));   //这个方法我会在名为方法三的下面贴出来

                for (int numRows = 1; numRows <= sheet.getLastRowNum(); numRows++) {

                    Row row = sheet.getRow(numRows);  //poi中的

                    Member member = new Member();       //我自己的实体类

                    for (int CellNum = 0; CellNum < row.getLastCellNum(); CellNum++) {

                        

                        Cell cell = row.getCell(CellNum);//poi中的

                        if(cell!=null){

                            cell.setCellType(Cell.CELL_TYPE_STRING);

                        }

                            switch (CellNum){

                            case 0://姓名                  //你Excel中的第一列,这里说一下哈,一定和你Excel中的顺序保持一致,下面我要是记起来再回啰嗦一句的

                                if(cell==null){

                                    member.setName("");

                                }else{

                                    member.setName(cell.toString());        

                                }

                                break;

                            case 1://名族

                                if(cell==null){

                                    member.setNation("");

                                }else{

                                    member.setNation(cell.toString());

                                }

                                break;

                            case 2://身份证号码

                                if(cell==null){

                                    member.setIdNumber("");

                                }else{

                                    member.setIdNumber(cell.toString());

                                    member.setUserName("a"+cell.toString());

                                }

                                break;

                            case 3://电话号码

                                if(cell==null){

                                    member.setPhoneNum("");

                                }else{                                    

                                    member.setPhoneNum(cell.toString());

                                }

                                break;

                            //邮箱

                            case 4:

                                if(cell==null){

                                    member.setEmail("");

                                }else{

                                    member.setEmail(cell.toString());

                                }

                                break;

                            //性别代码

                            case 5:

                                

                                if(cell==null){

                                    member.setGenderCode("");

                                

                                }else{

                                    member.setGenderCode(cell.toString());

                                }

                                break;

                            //性别

                            case 6:

                                

                                if(cell==null){

                                    member.setGenderName("");

                                }else{

                                    member.setGenderName(cell.toString());

                                }

                                break;

                            //出生日期

                    /*        case 10:

                                if(cell==null){

                                    member.setBirthday(null);

                                }else{

                                    SimpleDateFormat sdf=new SimpleDateFormat("dd-MM -yyyy");

                                    String birthTime=cell.toString();

                                    if(!StringUtils.isNullOrEmpty(birthTime)){

                                        

                                        Date date=sdf.parse(birthTime);

                                        member.setBirthday(date);

                                        //staffRegRequest.setBirthTime(date);

                                    }else{

                                        member.setBirthday(null);

                                        //staffRegRequest.setBirthTime(null);

                                    }

                                }

                                break;*/

                            //邮编

                            case 7:

                                if(cell==null){

                                    member.setZipCode("");

                                    //staffEmpoymentResponse.setJobTitleCode("");

                                }else{

                                    member.setZipCode(cell.toString());

                                }

                                break;

                            //现住址

                            case 8:

                                if(
9f20
cell==null){

                                    member.setAddress("");

                                }else{

                                    member.setAddress(cell.toString());

                                }

                                break;

            

                    }

                            

                    }

                member.setStatus("1");       //设置一些固定属性的值

                member.setAuditStatus("1");          //设置一些固定属性的值

                

                list.add(member);   //把实体类中设置的值封装到实体中后在放到list集合中

                }

                dto.setMembers(list);

                saveMemberList(dto);  //这里你们估计要变一下了,这是往数据库保存这个实体的方法,我里面还有调别的接口,就不把这个方法铺出来了,你们就直接把这个当做save方法存到数据库中就行。方法参数可以直接是实体类,不用我这里的dto。另外service和dao层我也不铺了,因为关系不大

                }else{

                    dto.setOpFlg("-1");

                    dto.setMsg("上传文件为空,请重新上传");

                }

                

            }else {

                dto.setOpFlg("-1");

                dto.setMsg("上传文件格式不正确,请选择excel格式文件上传");

            }

            

            

        

    }

这里做个简要说明啊,重要的代码我再后面做了批注。我觉得说的够啰嗦了,而且关键也说清楚了哈。没意见的往下看,有意见的可以关了。嘻嘻嘻嘻,哈哈哈

方法一

public static String getFileExp(String fileName) throws Exception{

        int pos = fileName.lastIndexOf(".");

        return fileName.substring(pos);

    }

方法二

    public static Workbook getWorkbook(File file) throws IOException, InvalidFormatException{

        FileInputStream inputStream=new FileInputStream(file);

        Workbook workbook=WorkbookFactory.create(inputStream);

        return workbook;

    }

方法三

    public static Sheet deleteNullRow(Sheet sheet){

        if(sheet!=null){

            Row row = null;

            Cell cell = null;

            for (int numRows = 1; numRows <= sheet.getLastRowNum(); numRows++){

                row = sheet.getRow(numRows);

                boolean nullRowMark = true;

                //每一行的前三列如果都为空则删掉这行

                for(int numCells = 0; numCells<=2; numCells++){

                    cell = row.getCell(numCells);

                    nullRowMark = nullRowMark&&(cell==null||cell.getCellType()==HSSFCell.CELL_TYPE_BLANK);

                }

                //删除空行

                if(nullRowMark){

                    int ls=sheet.getLastRowNum();

                    sheet.shiftRows(numRows, numRows, ls-numRows);

                    numRows = numRows-1;

                    Row nullrow=sheet.getRow(ls);  

                    sheet.removeRow(nullrow);

                }

            }

        }

        return sheet;

    }

那么至此,这不武功秘籍就差不多完结了。祝各位小伙伴早日修行得道啊。觉得有用就支持一下下下下啊
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: