zoukankan      html  css  js  c++  java
  • POI 导入excel 代码记录 方便以后粘贴

    import java.io.FileInputStream;
    import java.io.InputStream;
    
    import javax.annotation.Resource;
    
    import org.apache.poi.hssf.usermodel.HSSFWorkbook;
    import org.apache.poi.openxml4j.opc.OPCPackage;
    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;

    public class POIImport { @Resource private IBaseInfoService baseInfoService; public void poiImport() throws Exception { InputStream is = new FileInputStream("D:/temp.xlsx"); // 使用 Workbook 接口,解决2003版本和2007版本的excel 异常问题 Workbook book = null; try { book = new XSSFWorkbook(OPCPackage.open(is)); } catch (Exception ex) { book = new HSSFWorkbook(is); } // 定义接收表单数据的对象 BaseInfo baseInfo = null; // 循环工作表Sheet for (int numSheet = 0; numSheet < book.getNumberOfSheets(); numSheet++) { Sheet sheet = book.getSheetAt(0); if (sheet == null) { continue; } // 循环行Row for (int rowNum = 1; rowNum <= sheet.getLastRowNum(); rowNum++) { Row row = sheet.getRow(rowNum); if (row != null) { baseInfo = new BaseInfo(); // 得到行数据 Cell code = row.getCell(0); Cell ncCode = row.getCell(1); Cell name = row.getCell(2); Cell contPrice = row.getCell(3); // 为对象赋值 baseInfo.setCode(getValue(code)); baseInfo.setNcCode(getValue(ncCode)); baseInfo.setName(getValue(name)); baseInfo.setContPrice(Double.valueOf(getValue(contPrice))); // 插入数据表 baseInfoService.insertBaseInfo(baseInfo); } } } } // Cell 转 String private String getValue(Cell cell) { if (cell.getCellType() == cell.CELL_TYPE_BOOLEAN) { // 返回布尔类型的值 return String.valueOf(cell.getBooleanCellValue()); } else if (cell.getCellType() == cell.CELL_TYPE_NUMERIC) { // 返回数值类型的值 return String.valueOf(cell.getNumericCellValue()); } else { // 返回字符串类型的值 return String.valueOf(cell.getStringCellValue()); } } }
  • 相关阅读:
    Django ajax 实现 loading 效果
    K8S service 简单介绍
    K8S Pod 生命周期 (二)
    异度之刃 Xenoblade 后感
    Nested Prefab Mode 嵌套预制体 保存问题 Dirty
    GIT速成
    Surface电池阈值
    如何删除通知栏无效图标(重置任务栏通知区域)
    Mouse For Winpad
    Re:LieF ~親愛なるあなたへ~ 后感
  • 原文地址:https://www.cnblogs.com/huaixiaonian/p/9238223.html
Copyright © 2011-2022 走看看