文档章节

Java上传和解析excel表

依米欧11
 依米欧11
发布于 2017/03/10 17:51
字数 449
阅读 111
收藏 0

页面jsp及js代码:

<script type="text/javascript">
      function submitExcel(url){
          $.ajaxMutiUpload({
            type:"post",
            url:url,
            secureuri:true,// 安全提交,默认为false
            dataType:'json',
            fileElementId:"zzsFile",//上传文件的id
            success:function(data){
               $("#operateWin").window('close');
                searchForm();
                $.messager.show({
                    title:'友情提示', 
                    msg:data.message
                });
             },
             error:function(XMLHttpRequest,textStatus,errorThrown){
                 $.messager.show({
                    title:'友情提示', 
                    msg:data.message
                });
             }
     });
      }
  </script>

<FORM id="moduleform" method="post">
      <TABLE  cellspacing="1" cellpadding="5" width="100%" class="tb_background2">
        <tr>
            <td style="text-align:center;">
                <input type="file" name="zzsFile" id="zzsFile"/>
            </td>
        </tr>
        <TR>
            <TD style="text-align:right;">
                    <a href="javascript:void(0)" class="easyui-linkbutton" data-options = "iconCls:'icon-ok'"     data-options = "iconCls:'icon-ok'" onclick="submitExcel('${pageContext.request.contextPath}/secondaryAction_uploadFile.action')">提交</a>
                    <a href="javascript:void(0)" class="easyui-linkbutton" data-options = "iconCls:'icon-back'"   onclick="closeWindow()">返回</a>
            </TD>
        </TR>
        <TR>
            <TD style="text-align:left;">温馨提示:
                <br>&nbsp;&nbsp;&nbsp;&nbsp;<font color="red"><B>只支持excel导入</B></font>
            </TD>
        </TR>
    </TABLE>
    </FORM>

后台java代码对excel文件进行解析:

//上传的文件:File zzsFile

//文件名称:String zzsFileFileName

//需要保存数据到的list:List<Secondary> secondaryList

public List<Secondary> loadUserInfo(File zzsFile, String zzsFileFileName,
            List<Secondary> secondaryList) {
        try {
            FileInputStream fis = new FileInputStream(zzsFile);
            Workbook wb = null;  
            if (zzsFileFileName.toLowerCase().endsWith("xls")) {   
                wb = new HSSFWorkbook(fis);  
            }else if(zzsFileFileName.toLowerCase().endsWith("xlsx")) {   
                wb = new XSSFWorkbook(fis);  
            }
        
            Sheet sheet = wb.getSheetAt(0);    
            int rowNum = sheet.getLastRowNum()+1;
            //i 从1开始表示第一行为标题 不包含在数据中  
            for(int i=1;i<rowNum;i++){
                Secondary secondary = new Secondary();
                Row row = sheet.getRow(i);    
                int cellNum = row.getLastCellNum();    
                for(int j=0;j<cellNum;j++){ 
                    Cell cell = row.getCell(j);
                    String cellValue = null;
                     if(cell != null){
                         cell.setCellType(Cell.CELL_TYPE_STRING);
                         cellValue = cell.getStringCellValue();
                     }
                     switch(j){//通过列数来判断对应插如的字段    
                         //数据中不应该保护ID这样的主键记录                        
                         //case 0 : user.setId(Integer.valueOf(cellValue));break;
                         case 0 : secondary.setSecondaryIdentity(cellValue);break;    
                         case 1 : secondary.setSecondaryName(cellValue);break;
                         case 2 : secondary.setSecondarySex(cellValue);break; 
                         case 3 : secondary.setSecondaryBirthday(cellValue);break;  
                         case 4 : secondary.setSecondaryProvince(cellValue);break; 
                         case 5 : secondary.setSecondaryCity(cellValue);break;   
                         case 6 : secondary.setSecondaryCounty(cellValue);break; 
                         case 7 : secondary.setSecondaryFreeTuition(cellValue);break; 
                         case 8 : secondary.setSecondaryFreeTerm(cellValue);break;
                         case 9 : secondary.setSecondaryAgriAccount(cellValue);break;
                         case 10 : secondary.setSecondaryAccountDes(cellValue);break;
                         case 11 : 
                             if(cellValue!=null&&cellValue.length()!=0){
      Dormitory dormitory = (Dormitory) getSession().get(Dormitory.class,Long.parseLong(cellValue));
                                 if(dormitory!=null){
                                     dormitory.setPeopleNum(dormitory.getPeopleNum()+1);
                                     if(dormitory.getPeopleNum()!=dormitory.getRentPeople()){
                                         secondary.setDormitory(dormitory);
                                         getSession().update(dormitory);
                                     }
                                 }
                             }
                             break;
                     } 
                }
                secondaryList.add(secondary); 
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return secondaryList;
    }

© 著作权归作者所有

依米欧11
粉丝 0
博文 3
码字总数 449
作品 0
广州
程序员
私信 提问
Java读取和解析Excel数据:基于Apache POI(二)

版权声明:本文为Zhang Phil原创文章,请不要转载! https://blog.csdn.net/zhangphil/article/details/85317882 Java读取和解析Excel数据:基于Apache POI(二) 假设附录1文章中的test.xl...

zhangphil
01/02
0
0
Excel解析小工具

Excel解析小工具 【业务需求】 基本流程: 用户上传Excel数据 ---> 处理数据 ---> 处理的结果以Excel格式提供下载。 原始数据为: 商品数据,按照商品ID排列,每条ID对应一条订单数据占Excel...

爱吃鱼的猫大哥
2016/09/23
24
5
Java之POI读取Excel的解决兼容性问题

在Java中,使用POI来进行excel的读取和解析是常用的一种做法;在office的excel中存在2007,2003两种不同的格式,通常情况下是以xls/xlsx的不同后缀来区分的,但用户可能不知道这个区别,所以会...

灌南高手No1
02/22
0
0
GrapeCity Documents for Excel 文档API组件 V2.2 新特性介绍

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 https://blog.csdn.net/powertoolsteam/article/details/96150843 GrapeCity Documents for ...

powertoolsteam
07/16
0
0
GrapeCity Documents for Excel 文档 API 组件 V2.2 版本发布

GrapeCity Documents for Excel 文档 API 组件 V2.2 正式发布,本次新版本包含诸多重量级产品功能,如:将带有形状的电子表格导出为 PDF、控制分页和电子表格内容、将 Excel 电子表格的特定页...

葡萄城技术团队
07/16
582
0

没有更多内容

加载失败,请刷新页面

加载更多

02.日志系统:一条SQL更新语句是如何执行的?

我们还是从一个表的一条更新语句说起,我们创建下面一张表: create table T(ID int primary key, c int); 如果要将ID=2这一行c的值加1,SQL可以这么写: update T set c=c+1 where ID=2; 前...

scgaopan
今天
9
0
【五分钟系列】掌握vscode调试技巧

调试前端js 准备一个前端项目 index.html <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1......

aoping
今天
8
0
PhotoShop 高级应用:USM锐化/S锐化/防抖

、 高反差锐化+混合模式:叠加模式 【将更多的边缘细节添加到图像中】

东方墨天
今天
9
0
Python数据可视化之matplotlib

常用模块导入 import numpy as npimport matplotlibimport matplotlib.mlab as mlabimport matplotlib.pyplot as pltimport matplotlib.font_manager as fmfrom mpl_toolkits.mplot3d i......

松鼠大帝
昨天
7
0
我用Bash编写了一个扫雷游戏

我在编程教学方面不是专家,但当我想更好掌握某一样东西时,会试着找出让自己乐在其中的方法。比方说,当我想在 shell 编程方面更进一步时,我决定用 Bash 编写一个扫雷游戏来加以练习。 我在...

老孟的Linux私房菜
昨天
15
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部