`

poi解析excel

 
阅读更多
在我们的项目当中经常会遇到把数据导入到Excel中,或者读取Excel中的数据到数据库中,用Apache POI可以很方便的实现,Apache POI是Apache基金会的开放源码函式库,可以在其官网上下载其Jar包,官网是http://poi.apache.org,下载后把里面所有的jar包拷贝到项目中(其中不仅仅是根目录下的Jar包),好,我们先来看看如何写入数据到Excel中,注意,这里讲的是针对Excel 2007的,如果是以前的版本的,读取的方式是不一样的,请注意:

Java代码复制代码
import java.io.FileNotFoundException;  
import java.io.FileOutputStream;  
import java.io.IOException;  
 
import org.apache.poi.ss.usermodel.CreationHelper;  
import org.apache.poi.ss.usermodel.Row;  
import org.apache.poi.ss.usermodel.Sheet;  
import org.apache.poi.ss.usermodel.Workbook;  
import org.apache.poi.xssf.usermodel.XSSFWorkbook;  
/** 
* 写入数据到Excel 
* @author http://www.lookhan.com 

*/ 
public class WriteExcel{  
       
      public static void main(String[] args){  
          try{  
              Workbook wb = new XSSFWorkbook();  
              CreationHelper createHelper = wb.getCreationHelper();  
              //创建页  
              Sheet sheet = wb.createSheet("sheet1");  
              // 创建行  
              Row row = sheet.createRow((short) 0);  
              // 创建单元格  
              row.createCell(0).setCellValue(258258258);  
              row.createCell(1).setCellValue(0.67);  
              row.createCell(2).setCellValue(createHelper.createRichTextString("http://www.lookhan.com"));  
              row.createCell(3).setCellValue(createHelper.createRichTextString("Java知识笔记"));  
              // 写入文件  
              FileOutputStream fileOut = null;  
              fileOut = new FileOutputStream("D:\\lookhan.xlsx");  
              wb.write(fileOut);  
              fileOut.close();  
              System.out.println("写入成功!");  
          } catch (FileNotFoundException e){  
              e.printStackTrace();  
          } catch (IOException e){  
              e.printStackTrace();  
          }  
      }  
        
}  
上面的测试类运行后,你就能在D盘下看到Excel文件了。

再看看如何读取Excel,首先定义一个自定义异常类,便于提示在读取Excel文件时出错的地方,因为一般对Excel的读取情况常见的是导入Excel数据到数据库中,一般如果用户在导入出错的话,可能是某个单元格的格式不对,用一个自定义异常可以很好的提示:

Java代码复制代码
/** 
* 读取Excel时格式错误的自定义Exception 
* @author http://www.lookhan.com 

*/ 
public class ExcelFormatException extends Exception {  
 
    private static final long serialVersionUID = 3435456589196458401L;  
    private int row;  
    private int column;  
      
    public ExcelFormatException(String message, int row, int column){  
        super(message);  
        this.row = row;  
        this.column = column;  
    }  
    //出错的行  
    public int getRow() {  
        return row;  
    }  
    //出错的列  
    public int getColumn() {  
        return column;  
    }  
      

再来看看测试类:

Java代码复制代码
import java.io.FileInputStream;  
import java.io.InputStream;  
 
import org.apache.poi.ss.usermodel.Cell;  
import org.apache.poi.ss.usermodel.DateUtil;  
import org.apache.poi.ss.usermodel.Row;  
import org.apache.poi.ss.usermodel.Sheet;  
import org.apache.poi.ss.usermodel.Workbook;  
import org.apache.poi.ss.usermodel.WorkbookFactory;  
/** 
* 测试对Excel的读取 
* @author http://www.lookhan.com 

*/ 
public class ReaderExcel {  
 
    public static void main(String[] args){  
        String src = "D:\\lookhan.xlsx";  
        try {  
            ReaderExcel test = new ReaderExcel();  
            test.getExcel(src);  
        } catch (Exception e) {  
            ExcelFormatException excelException = (ExcelFormatException)e;  
            System.out.println(excelException.getMessage()+"行:"+excelException.getColumn()+"列:"+excelException.getRow());  
        }  
    }  
 
    public void getExcel(String src) throws Exception{  
          
        InputStream inp;  
        inp = new FileInputStream(src);  
        Workbook wb = WorkbookFactory.create(inp);  
        //读取第一页  
        Sheet sheet = wb.getSheetAt(0);  
        //从第二行开始到最后一行(第一行是标题)  
        for(int i=1; i1;i++){  
            Row row = sheet.getRow(i);  
            //循环四列(Excel是四列)  
            for (int j=0; j<4; j++){  
                Cell cell = row.getCell(j);  
                if(j == 0){  
                    switch (cell.getCellType()){  
                        case Cell.CELL_TYPE_NUMERIC:  
                            if (DateUtil.isCellDateFormatted(cell)){  
                                System.out.println(cell.getDateCellValue());  
                            } else {  
                                throw new ExcelFormatException("格式错误",(cell.getRowIndex()+1),(cell.getColumnIndex()+1));  
                            }  
                            break;  
                        default:  
                            throw new ExcelFormatException("格式错误",(cell.getRowIndex()+1),(cell.getColumnIndex()+1));  
                    }  
                }  
                if(j == 1){  
                    switch (cell.getCellType()){  
                        case Cell.CELL_TYPE_STRING:  
                            System.out.println(cell.getRichStringCellValue());  
                            break;  
                        case Cell.CELL_TYPE_NUMERIC:  
                            if (DateUtil.isCellDateFormatted(cell)){  
                                System.out.println(cell.getDateCellValue().toString());  
                            } else {  
                                System.out.println(cell.getNumericCellValue());  
                            }  
                            break;  
                        case Cell.CELL_TYPE_BOOLEAN:  
                            System.out.println(cell.getBooleanCellValue());  
                            break;  
                        case Cell.CELL_TYPE_FORMULA:  
                            System.out.println(cell.getCellFormula());  
                            break;  
                        default:  
                            throw new ExcelFormatException("格式错误",(cell.getRowIndex()+1),(cell.getColumnIndex()+1));  
                    }  
                }  
                if(j == 2){  
                    switch (cell.getCellType()){  
                        case Cell.CELL_TYPE_STRING:  
                            System.out.println(cell.getRichStringCellValue());  
                            break;  
                        case Cell.CELL_TYPE_NUMERIC:  
                            if (DateUtil.isCellDateFormatted(cell)){  
                                System.out.println(cell.getDateCellValue());  
                            } else {  
                                System.out.println(cell.getNumericCellValue());  
                            }  
                            break;  
                        case Cell.CELL_TYPE_BOOLEAN:  
                            System.out.println(cell.getBooleanCellValue());  
                            break;  
                        case Cell.CELL_TYPE_FORMULA:  
                            System.out.println(cell.getCellFormula());  
                            break;  
                        default:  
                            throw new ExcelFormatException("格式错误",(cell.getRowIndex()+1),(cell.getColumnIndex()+1));  
                    }  
                }  
                if(j == 3){  
                    switch (cell.getCellType()){  
                        case Cell.CELL_TYPE_STRING:  
                            System.out.println(cell.getRichStringCellValue());  
                            break;  
                        case Cell.CELL_TYPE_NUMERIC:  
                            if (DateUtil.isCellDateFormatted(cell)){  
                                throw new ExcelFormatException("格式错误",(cell.getRowIndex()+1),(cell.getColumnIndex()+1));  
                            } else {  
                                System.out.println(cell.getNumericCellValue());  
                            }  
                            break;  
                        case Cell.CELL_TYPE_BOOLEAN:  
                            throw new ExcelFormatException("格式错误",(cell.getRowIndex()+1),(cell.getColumnIndex()+1));  
                        case Cell.CELL_TYPE_FORMULA:  
                            throw new ExcelFormatException("格式错误",(cell.getRowIndex()+1),(cell.getColumnIndex()+1));  
                        default:  
                            throw new ExcelFormatException("格式错误",(cell.getRowIndex()+1),(cell.getColumnIndex()+1));  
                    }  
                }  
            }  
        }  
        inp.close();  
          
    }  
      
分享到:
评论

相关推荐

    使用POI解析excel文件并写入数据库

    使用poi解析excel文件,并将数据写入到数据库 项目说明 这个项目实现的功能是读取excel文件中的数据,解析并写入数据库。 读取的excel文件位于项目目录下的 excel\0805.xlsx 使用IntelliJ IDEA开发此项目 使用MYSQL...

    Java Poi 解析EXCEL数据

    以上就是使用Java Poi解析Excel数据的基本流程。在实际应用中,你可能还需要处理其他复杂场景,比如样式、公式、超链接等。Poi库提供了丰富的API来处理这些问题,使得与Excel文件的交互变得简单且灵活。在提供的"poi...

    利用POI解析excel并存入数据库demo

    在这个"利用POI解析excel并存入数据库demo"中,我们将关注如何使用 POI 库来读取 Excel 文件,并将数据有效地存入 MySQL 数据库。 首先,要开始使用 POI,你需要在你的项目中引入相应的依赖。如果你使用的是 Maven...

    poi解析excel文件

    标题提到的"poi解析excel文件"是利用Apache POI 3.8版本进行Excel数据的读取和解析。 在Apache POI 3.8中,主要涉及以下核心概念: 1. **HSSF(Horrible Spreadsheet Format)**:这是Apache POI中处理旧版Excel...

    POI解析EXCEl分层

    标题“POI解析EXCEL分层”涉及到的主要知识点是Apache POI库在处理Microsoft Excel文件时的层次化数据解析。Apache POI是一个流行的开源Java API,它允许开发者读取、写入和修改Microsoft Office格式的文件,其中...

    poi 解析excel文件内容demo

    在这个"poi 解析excel文件内容demo"中,我们主要关注如何使用Apache POI库来读取和解析Excel文件,无论它们是2003版的.XLS还是2007以后的.XLSX格式。 首先,Apache POI提供了两种主要的接口来处理Excel文件:HSSF...

    poi解析excel的poi包

    以上就是使用Apache POI解析Excel文件并将数据存入Oracle数据库的基本步骤。在实际应用中,你可能需要根据具体需求进行调整,例如处理不同类型的单元格(数字、日期等)、异常处理、优化性能等。

    POI解析Excel简单实例

    POI解析Excel简单实例

    apache poi解析Excel时报错,我将Excel打开后保存,就不会报错,用jar完美解决

    apache poi解析Excel时报错,我将Excel打开后保存,就不会报错,我将重写的类从新打包这样问题虽然网上有解决方案,但是需要自己打包重写对应类,我已将这些步骤做好了。

    POI解析excel并存入mysqlのdemo

    这个“POI解析excel并存入mysqlのdemo”是利用 Java 的 Apache POI 库来读取 Excel 数据,并将这些数据存储到 MySQL 数据库中的示例。下面我们将详细探讨相关的知识点。 1. **Apache POI**: Apache POI 是一个...

    poi 解析excel实例

    在描述中提到的“ poi解析excel的工具类”,通常包含了一些常用的方法,例如打开文件、读取单元格数据、处理合并单元格等。以下是一些可能包含在该工具类中的关键方法: 1. **打开文件**:使用`WorkbookFactory`类...

    POI解析Excel文档

    【标题】"POI解析Excel文档"涉及到的主要技术是Apache POI库,它是一个用于读取和写入Microsoft Office格式档案的开源Java API。在Java编程环境中,使用POI库可以方便地处理Excel(.xlsx和.xls)文件,进行数据的...

    poi解析Excel所需要的包

    在Java环境中,使用Apache POI库解析Excel文件时,确实需要引入一系列的依赖包来确保所有必要的功能得以正常运行。这些包包含了对Excel文件格式的理解和支持,允许开发者读取、写入和修改Excel数据。 1. **Apache ...

    poi解析excel2007

    最新版poi解析excel2007源码,简单实用,需要的可下.

    通过poi解析Excel示例

    本示例将深入讲解如何使用Apache POI来解析Excel文件。 Apache POI是Apache软件基金会的一个开源项目,它的主要功能是处理微软的Office Open XML (OOXML) 和早期的二进制文件格式,例如Excel的.BIFF8格式。在Java中...

    使用poi解析Excel

    《使用POI解析Excel》 在信息技术领域,处理数据是日常工作中不可或缺的一部分,而Excel作为广泛使用的电子表格软件,其数据处理能力强大且灵活。Apache POI是一个开源库,专门用于读取和写入Microsoft Office格式...

    POI解析excel

    在本文中,我们将深入探讨如何使用POI解析Excel 2013和2017版本的文件,并将结果转换为List集合。 一、Apache POI简介 Apache POI是Apache软件基金会的一个开源项目,它提供了API来读取、写入和修改Microsoft ...

Global site tag (gtag.js) - Google Analytics