<!--poi对excel2007以上版本的支持--> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>3.12</version> </dependency>
/** * 处理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(); } }
版权声明:本文为博主原创文章,未经博主允许不得转载。
原文地址:http://blog.csdn.net/js_sky/article/details/47334833