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

 

你可能感兴趣的:(Excel)