Java的poi技术遍历Excel时进行空Cell,空row,判断
- /**
- * 导入信息
- */
- @Override
- public List<Object> add(HttpServletRequest request) {
- // TODO Auto-generated method stub
- List<Object> num=new ArrayList<Object>();
- MultipartHttpServletRequest multipartRequest =(MultipartHttpServletRequest) request;
- CommonsMultipartFile file = (CommonsMultipartFile)multipartRequest.getFile("zlUpload");
- if(file!=null){
- try {
- num = save(file.getInputStream());
- } catch (IOException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- }
- returnnum;
- }
- /**
- * 保存上传的Excel信息
- */
- private List<Object> save(InputStream inputStream) throwsIOException {
- // TODO Auto-generated method stub
- List<Object> error_num = new ArrayList<Object>();
- List<Object> temp =(List<Object>)readXls(inputStream,error_num);
- System.out.println(temp.get(0).getClass().getName());
- if(temp.get(0).getClass().getName().equals("org.apache.poi.hssf.usermodel.HSSFCell")){
- return error_num;
- }else{
- TStudentNo student = null;
- List<TStudentNo> studentList = newArrayList<TStudentNo>();
- for(int i=0;i<temp.size();i++){
- student = (TStudentNo)temp.get(i);
- studentList.add(student);
- }
- try {
- //在插入数据前进行判断,看数据库中是否有不允许重复的字段出现,以打断保存进度
- int repeat = 0;
- for(int j = 0;j<studentList.size();j++){
- TStudentNo Studenttemp =studentMapper.findByStudentNo(studentList.get(j).getStudent_no());
- //如果查到了,重复数加一,然后跳过不保存
- if(Studenttemp!=null){
- repeat++;
- }
- }
- if(repeat==0){
- for(int z=0;z<studentList.size();z++){
- studentMapper.saveStudent(studentList.get(z));
- }
- }else{
- error_num.add("数据库中有相同的数据,请检查学号等不允许重复的部分!");
- return error_num;
- }
- } catch (Exception e) {
- //判断Excel中是否有重复数据,如果有重复跳过保存异常
- error_num.add("数据库中有相同的数据,请检查学号等不允许重复的部分!");
- return error_num;
- }
- return temp;
- }
- }
- /**
- * 逐行遍历其Excel
- */
- private Object readXls(InputStream inputStream,List<Object>error_num) throws IOException {
- InputStream is = new BufferedInputStream(inputStream);
- HSSFWorkbook hssfWorkbook = new HSSFWorkbook(is);
- TStudentNo student = null;
- List<TStudentNo> list = new ArrayList<TStudentNo>();
- //循环工作表Sheet
- for(int numSheet =0;numSheet<hssfWorkbook.getNumberOfSheets();numSheet++){
- HSSFSheet hssfSheet = hssfWorkbook.getSheetAt(numSheet);
- if(hssfSheet == null){
- continue;
- }
- for(int rowNum =2;rowNum<=hssfSheet.getLastRowNum();rowNum++){
- System.out.println(hssfSheet.getLastRowNum());
- HSSFRow hssfRow = hssfSheet.getRow(rowNum);
- //检查每行的空格数,如果小于4证明有一个或多个空格,但不是整行
- if(CheckRowNull(hssfRow)<4){
- student = new TStudentNo();
- HSSFCell name = hssfRow.getCell(0);
- HSSFCell student_no = hssfRow.getCell(1);
- HSSFCell phone = hssfRow.getCell(2);
- HSSFCell class_no = hssfRow.getCell(3);
- HSSFCell subject_category = hssfRow.getCell(4);
- List<HSSFCell> temp = new ArrayList<HSSFCell>();
- temp.add(0, name);
- temp.add(1, student_no);
- temp.add(2, phone);
- temp.add(3, class_no);
- temp.add(4, subject_category);
- int temp1 = 0;//用于跳出双层for循环
- for(int i=0;i<5;i++){
- //为记录前台进行提示某行某列出错
- temp1 = CheckRowError(temp.get(i),error_num,rowNum,i);
- if(temp1==-1){
- break;
- }
- }
- if(temp1==-1){
- return temp;
- }
- student.setName(getCellValue(name));
- student.setPhone(getCellValue(phone));
- student.setStudent_no(getCellValue(student_no));
- student.setClass_no(getCellValue(class_no));
- student.setSubject_category(Integer.parseInt(getCellValue(subject_category)));
- list.add(student);
- }else{
- continue;
- }
- }
- }
- return list;
- }
- /**
- * 对Excel的各个单元格的格式进行判断并转换
- */
- private String getCellValue(HSSFCell cell) {
- String cellValue = "";
- DecimalFormat df = newDecimalFormat("#");
- switch (cell.getCellType()) {
- case HSSFCell.CELL_TYPE_STRING:
- cellValue =cell.getRichStringCellValue().getString().trim();
- break;
- case HSSFCell.CELL_TYPE_NUMERIC:
- cellValue =df.format(cell.getNumericCellValue()).toString();
- break;
- case HSSFCell.CELL_TYPE_BOOLEAN:
- cellValue =String.valueOf(cell.getBooleanCellValue()).trim();
- break;
- case HSSFCell.CELL_TYPE_FORMULA:
- cellValue =cell.getCellFormula();
- break;
- default:
- cellValue = "";
- }
- return cellValue;
- }
- //判断某行某列有问题
- private int CheckRowError(HSSFCell cell,List<Object>error_num,int rowNum,int cell_num){
- //判断各个单元格是否为空
- if(cell==null||cell.equals("")||cell.getCellType() ==HSSFCell.CELL_TYPE_BLANK){
- error_num.add("出错啦!请检查第"+(rowNum+1)+"行第"+(cell_num+1)+"列。"+"如果您在该行没有数据,建议您选择删除该行,重试!");
- return -1;
- }
- return 0;
- }
- //判断行为空
- private int CheckRowNull(HSSFRow hssfRow){
- int num = 0;
- Iterator<Cell> cellItr =hssfRow.iterator();
- while(cellItr.hasNext()){
- Cell c =cellItr.next();
- if(c.getCellType() ==HSSFCell.CELL_TYPE_BLANK){
- num++;
- }
- }
- return num;
- }
Java的poi技术遍历Excel时进行空Cell,空row,判断的更多相关文章
- java的poi技术写Excel的Sheet
在这之前写过关于java读,写Excel的blog如下: Excel转Html java的poi技术读,写Excel[2003-2007,2010] java的poi技术读取Excel[2003-20 ...
- java的poi技术读取Excel[2003-2007,2010]
这篇blog主要是讲述java中poi读取excel,而excel的版本包括:2003-2007和2010两个版本, 即excel的后缀名为:xls和xlsx. 读取excel和MySQL相关: ja ...
- java的poi技术读取Excel数据
这篇blog主要是讲述java中poi读取excel,而excel的版本包括:2003-2007和2010两个版本, 即excel的后缀名为:xls和xlsx. 读取excel和MySQL相关: ja ...
- java的poi技术读取Excel[2003-2007,2010]
这篇blog主要是讲述java中poi读取excel,而excel的版本包括:2003-2007和2010两个版本, 即excel的后缀名为:xls和xlsx. 读取excel和MySQL相关: ja ...
- java的poi技术读取Excel数据到MySQL
这篇blog是介绍java中的poi技术读取Excel数据,然后保存到MySQL数据中. 你也可以在 : java的poi技术读取和导入Excel了解到写入Excel的方法信息 使用JXL技术可以在 ...
- java的poi技术下载Excel模板上传Excel读取Excel中内容(SSM框架)
使用到的jar包 JSP: client.jsp <%@ page language="java" contentType="text/html; charset= ...
- java的poi技术读,写Excel[2003-2007,2010]
在上一篇blog:java的poi技术读取Excel[2003-2007,2010] 中介绍了关于java中的poi技术读取excel的相关操作 读取excel和MySQL相关: java的poi技术 ...
- java的poi技术读取和导入Excel实例
本篇文章主要介绍了java的poi技术读取和导入Excel实例,报表输出是Java应用开发中经常涉及的内容,有需要的可以了解一下. 报表输出是Java应用开发中经常涉及的内容,而一般的报表往往缺乏通用 ...
- Java利用POI导入导出Excel中的数据
首先谈一下今天发生的一件开心的事,本着一颗android的心我被分配到了PB组,身在曹营心在汉啊!好吧,今天要记录和分享的是Java利用POI导入导出Excel中的数据.下面POI包的下载地 ...
随机推荐
- BZOJ 3622: 已经没有什么好害怕的了(二项式反演)
传送门 解题思路 首先将\(a\),\(b\)排序,然后可以算出\(t(i)\),表示\(a(i)\)比多少个\(b(i)\)大,根据容斥套路,设\(f(k)\)表示恰好有\(k\)个\(a(i)\) ...
- ibatis 中的 $和#的区别
在sql配置中比如in(#rewr#) 与in ($rewr$) 在Ibatis中我们使用SqlMap进行Sql查询时需要引用参数,在参数引用中遇到的符号#和$之间的区分为,#可以进行与编译,进行类型 ...
- jquery中attr方法和prop方法的区别
关于checked的属性,最重要的概念就是你要记住,它跟checked的状态值是毫无关系的,设置checked = "checked"或者checked = "true& ...
- 用processing画李萨如曲线
李萨如曲线 有没有对示波器上变化曲线产生过兴趣,它叫做李萨如曲线: 数学上,利萨茹(Lissajous)曲线(又称利萨茹图形.李萨如图形或鲍迪奇(Bowditch)曲线)是两个沿着互相垂直方向的正弦振 ...
- flex属性flex-grow、flex-shrink、flex-basis
tip: 1)这些属性写在子元素中,作用于子元素(父元素中应设置display:flex) 2)作用是子元素如何分配父元素的空间 3) flex-grow 是扩展比率,当子元素宽度总和小于父元素宽度时 ...
- Rust <7>:数据结构==>链表
enum List { Cons(u64, Box<List>), NULL, } impl List { fn new() -> List { List::NULL } fn pr ...
- git 上传你代码到码云
转载自:http://blog.csdn.net/u013776188/article/details/60867437
- Jmeter+ InfluxDB+Grafana安装配置
前置条件: 系统:windows jmeter:5.1 InfluxDB安装 下载InfluxDB-v1.7.9和Chronograf-v1.7.14(InfluxDB的可视化web端). 下载完成之 ...
- python-模块-包
一 模块 1 什么是模块? 常见的场景:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 但其实import加载的模块分为四个通用类别: 1 使用python编 ...
- CG-CTF CRYPTO部分wp
1,easybase64解密得flag 2,keyboard键盘码,在键盘上画画得flag:areuhack 3,异性相吸根据提示,写脚本 with open('密文.txt')as a: a=a.r ...