zoukankan      html  css  js  c++  java
  • java使用poi.3.10读取excel 2007以上版本(xlsx格式)

    1、在使用过程中,一直报错 throw new ClassNotFoundException(name);原因:没有导入xmlbeans-2.6.0.jar包,建议在使用poi时,将所有包都导入进工程。

    2、案例源码

    import java.io.FileInputStream;
    import java.io.IOException;
    import java.io.InputStream;
    import java.util.Iterator;
    import org.apache.poi.hssf.usermodel.HSSFCell;
    import org.apache.poi.hssf.usermodel.HSSFWorkbook;
    import org.apache.poi.ss.usermodel.Cell;
    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;
    import org.junit.Test;
     
    public class TestExcelS {
        
        public static String filePath = TestExcel.class.getResource("/test.xlsx").getPath();
        @Test
        public static void main(String[] args) {
            readXml(filePath);
            System.out.println("-------------");
         }
        public static void readXml(String fileName){
            boolean isE2007 = false;    //判断是否是excel2007格式
            if(fileName.endsWith("xlsx"))
                isE2007 = true;
            try {
                InputStream input = new FileInputStream(fileName);    //建立输入流
                Workbook wb  = null;
                //根据文件格式(2003或者2007)来初始化
                if(isE2007)
                    wb = new XSSFWorkbook(input);
                else
                    wb = new HSSFWorkbook(input);
                Sheet sheet = wb.getSheetAt(0);        //获得第一个表单
                Iterator<Row> rows = sheet.rowIterator();    //获得第一个表单的迭代器
                while (rows.hasNext()) {
                    Row row = rows.next();    //获得行数据
                    System.out.println("Row #" + row.getRowNum());    //获得行号从0开始
                    Iterator<Cell> cells = row.cellIterator();    //获得第一行的迭代器
                    while (cells.hasNext()) {
                        Cell cell = cells.next();
                        System.out.println("Cell #" + cell.getColumnIndex());
                        switch (cell.getCellType()) {    //根据cell中的类型来输出数据
                        case HSSFCell.CELL_TYPE_NUMERIC:
                            System.out.println(cell.getNumericCellValue());
                            break;
                        case HSSFCell.CELL_TYPE_STRING:
                            System.out.println(cell.getStringCellValue());
                            break;
                        case HSSFCell.CELL_TYPE_BOOLEAN:
                            System.out.println(cell.getBooleanCellValue());
                            break;
                        case HSSFCell.CELL_TYPE_FORMULA:
                            System.out.println(cell.getCellFormula());
                            break;
                        default:
                            System.out.println("unsuported sell type");
                        break;
                        }
                    }
                }
            } catch (IOException ex) {
                ex.printStackTrace();
            }
        }
    }

    相关代码注释可参考Java使用poi读取Excel2003

  • 相关阅读:
    Dumps for Dummies Dump Analysis Tutorial
    WCF 学习资料
    winform 跨线程设置或读取控件的属性
    反射通过属性名得到属性的值
    C# 不用循环填充数组
    反射字符串调用方法
    使用反射打开窗体,并控制一个窗体只能打开一个
    绘制圆角窗体和圆角panel
    WinForm使用反射通过控件的name得到该控件
    winfrom 绘制圆形按钮
  • 原文地址:https://www.cnblogs.com/hehaiyang/p/4113594.html
Copyright © 2011-2022 走看看