记录一下工作中应用的poi(能够做为工具类来应用)

/** * 解决excel读入的工具类 * Created by Liujishuai on 2015/8/5. */public class ExcelUtils {    /**     * 要求excel版本在2007以上     *     * @param file 文件信息     * @return     * @throws Exception     */    public static List<List<Object>> readExcel(File file) throws Exception {        if(!file.exists()){            throw new Exception("找不到文件");        }        List<List<Object>> list = new LinkedList<List<Object>>();        XSSFWorkbook xwb = new XSSFWorkbook(new FileInputStream(file));        // 读取第一张表格内容        XSSFSheet sheet = xwb.getSheetAt(0);        XSSFRow row = null;        XSSFCell cell = null;        for (int i = (sheet.getFirstRowNum() + 1); i <= (sheet.getPhysicalNumberOfRows() - 1); i++) {            row = sheet.getRow(i);            if (row == null) {                continue;            }            List<Object> linked = new LinkedList<Object>();            for (int j = row.getFirstCellNum(); j <= row.getLastCellNum(); j++) {                Object value = null;                cell = row.getCell(j);                if (cell == null) {                    continue;                }                switch (cell.getCellType()) {                    case XSSFCell.CELL_TYPE_STRING:                        //String类型返回String数据                        value = cell.getStringCellValue();                        break;                    case XSSFCell.CELL_TYPE_NUMERIC:                        //日期数据返回LONG类型的工夫戳                        if ("yyyy\"年\"m\"月\"d\"日\";@".equals(cell.getCellStyle().getDataFormatString())) {                            //System.out.println(cell.getNumericCellValue()+":日期格局:"+cell.getCellStyle().getDataFormatString());                            value = DateUtils.getMillis(HSSFDateUtil.getJavaDate(cell.getNumericCellValue())) / 1000;                        } else {                            //数值类型返回double类型的数字                            //System.out.println(cell.getNumericCellValue()+":格局:"+cell.getCellStyle().getDataFormatString());                            value = cell.getNumericCellValue();                        }                        break;                    case XSSFCell.CELL_TYPE_BOOLEAN:                        //布尔类型                        value = cell.getBooleanCellValue();                        break;                    case XSSFCell.CELL_TYPE_BLANK:                        //空单元格                        break;                    default:                        value = cell.toString();                }                if (value != null && !value.equals("")) {                    //单元格不为空,则退出列表                    linked.add(value);                }            }            if (linked.size()!= 0) {                list.add(linked);            }        }        return list;    }    /**     * 要求excel版本在2007以上     *     * @param fileInputStream 文件信息     * @return     * @throws Exception     */    public static List<List<Object>> readExcel(FileInputStream fileInputStream) throws Exception {        List<List<Object>> list = new LinkedList<List<Object>>();        XSSFWorkbook xwb = new XSSFWorkbook(fileInputStream);        // 读取第一张表格内容        XSSFSheet sheet = xwb.getSheetAt(1);        XSSFRow row = null;        XSSFCell cell = null;        for (int i = (sheet.getFirstRowNum() + 1); i <= (sheet.getPhysicalNumberOfRows() - 1); i++) {            row = sheet.getRow(i);            if (row == null) {                continue;            }            List<Object> linked = new LinkedList<Object>();            for (int j = row.getFirstCellNum(); j <= row.getLastCellNum(); j++) {                Object value = null;                cell = row.getCell(j);                if (cell == null) {                    continue;                }                switch (cell.getCellType()) {                    case XSSFCell.CELL_TYPE_STRING:                        value = cell.getStringCellValue();                        break;                    case XSSFCell.CELL_TYPE_NUMERIC:                        if ("yyyy\"年\"m\"月\"d\"日\";@".equals(cell.getCellStyle().getDataFormatString())) {                            //System.out.println(cell.getNumericCellValue()+":日期格局:"+cell.getCellStyle().getDataFormatString());                            value = DateUtils.getMillis(HSSFDateUtil.getJavaDate(cell.getNumericCellValue())) / 1000;                        } else {                            //System.out.println(cell.getNumericCellValue()+":格局:"+cell.getCellStyle().getDataFormatString());                            value = cell.getNumericCellValue();                        }                        break;                    case XSSFCell.CELL_TYPE_BOOLEAN:                        value = cell.getBooleanCellValue();                        break;                    case XSSFCell.CELL_TYPE_BLANK:                        break;                    default:                        value = cell.toString();                }                if (value != null && !value.equals("")) {                    //单元格不为空,则退出列表                    linked.add(value);                }            }            if (linked.size()!= 0) {                list.add(linked);            }        }        return list;    }     /**     * 导出excel     * @param excel_name 导出的excel门路(须要带.xlsx)     * @param headList  excel的题目备注名称     * @param fieldList excel的题目字段(与数据中map中键值对应)     * @param dataList  excel数据     * @throws Exception     */    public static void createExcel(String excel_name, String[] headList,                                   String[] fieldList, List<Map<String, Object>> dataList)            throws Exception {        // 创立新的Excel 工作簿        XSSFWorkbook workbook = new XSSFWorkbook();        // 在Excel工作簿中建一工作表,其名为缺省值        XSSFSheet sheet = workbook.createSheet();        // 在索引0的地位创立行(最顶端的行)        XSSFRow row = sheet.createRow(0);        // 设置excel头(第一行)的头名称        for (int i = 0; i < headList.length; i++) {             // 在索引0的地位创立单元格(左上端)            XSSFCell cell = row.createCell(i);            // 定义单元格为字符串类型            cell.setCellType(XSSFCell.CELL_TYPE_STRING);            // 在单元格中输出一些内容            cell.setCellValue(headList[i]);        }        // ===============================================================        //增加数据        for (int n = 0; n < dataList.size(); n++) {            // 在索引1的地位创立行(最顶端的行)            XSSFRow row_value = sheet.createRow(n + 1);            Map<String, Object> dataMap = dataList.get(n);            // ===============================================================            for (int i = 0; i < fieldList.length; i++) {                 // 在索引0的地位创立单元格(左上端)                XSSFCell cell = row_value.createCell(i);                // 定义单元格为字符串类型                cell.setCellType(XSSFCell.CELL_TYPE_STRING);                // 在单元格中输出一些内容                cell.setCellValue((dataMap.get(fieldList[i])).toString());            }            // ===============================================================        }        // 新建一输入文件流        FileOutputStream fos = new FileOutputStream(excel_name);        // 把相应的Excel 工作簿存盘        workbook.write(fos);        fos.flush();        // 操作完结,敞开文件        fos.close();    }}

在应用poi之前要导入相干的jar包(poi的jar包的作用)


应用之前导入jar包

<!--poi对excel2007以上版本的反对-->        <dependency>            <groupId>org.apache.poi</groupId>            <artifactId>poi-ooxml</artifactId>            <version>3.12</version>        </dependency>

在应用poi时在导入excel文件时遇到了### java.lang.ClassNotFoundException异样
解决的计划是:
导入了jar包

<!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml --><dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>4.1.2</version></dependency><dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml-schemas</artifactId> <version>4.1.2</version></dependency>

要留神版本,不要造成版本抵触.