java 使用poi 导入Excel数据到数据库的步骤

2020-12-14 0 490

由于我个人电脑装的Excel是2016版本的,所以这地方我使用了XSSF 方式导入 。

1 先手要制定一个Excel 模板 把模板放入javaWeb工程的某一个目录下如图:

java 使用poi 导入Excel数据到数据库的步骤

2 模板建好了后,先实现模板下载功能 下面是页面jsp代码在这里只贴出部分代码

<!-- excel 导入小模块窗口 -->
<div id=\"importBox\" class=\"\" style=\"display: none;\">
  <form id=\"importForm\" action=\"<%=basePath%>book/dishes/backstageversion/list!importExcel\" method=\"post\" enctype=\"multipart/form-data\"
   class=\"form-search\" style=\"padding-left:20px;text-align:center;\" onsubmit=\"loading(\'正在导入,请稍等...\');\"><br/>
   <input id=\"uploadFile\" name=\"file\" type=\"file\" style=\"width:330px\"/><br/><br/>  
   <input id=\"btnImportSubmit\" class=\"btn btn-primary\" type=\"submit\" value=\" 导 入 \"/>
   <input type=\"hidden\" id=\"importCompanyId\" name=\"importCompanyId\" value=\"\"/>
   <input type=\"hidden\" id=\"importStallId\" name=\"importStallId\" value=\"\"/>
   <a href=\"<%=basePath%>book/dishes/backstageversion/list!exportOrder\" rel=\"external nofollow\" rel=\"external nofollow\" >下载模板</a>
  </form>
</div>
<!-- excel 导入小模块窗口 -->
<div id=\"importBox\" class=\"\" style=\"display: none;\">
  <form id=\"importForm\" action=\"<%=basePath%>book/dishes/backstageversion/list!importExcel\" method=\"post\" enctype=\"multipart/form-data\"
   class=\"form-search\" style=\"padding-left:20px;text-align:center;\" onsubmit=\"loading(\'正在导入,请稍等...\');\"><br/>
   <input id=\"uploadFile\" name=\"file\" type=\"file\" style=\"width:330px\"/><br/><br/>  
   <input id=\"btnImportSubmit\" class=\"btn btn-primary\" type=\"submit\" value=\" 导 入 \"/>
   <input type=\"hidden\" id=\"importCompanyId\" name=\"importCompanyId\" value=\"\"/>
   <input type=\"hidden\" id=\"importStallId\" name=\"importStallId\" value=\"\"/>
   <a href=\"<%=basePath%>book/dishes/backstageversion/list!exportOrder\" rel=\"external nofollow\" rel=\"external nofollow\" >下载模板</a>
  </form>
</div>

下面是js

<!-- Bootstrap -->
 <link href=\"<%=path %>/res/admin/css/bootstrap.min.css\" rel=\"external nofollow\" rel=\"stylesheet\" type=\"text/css\" /> 
 <link href=\"<%=path %>/res/admin/css/xy_css.css\" rel=\"external nofollow\" rel=\"stylesheet\" type=\"text/css\">
 <link href=\"<%=path %>/res/admin/css/font-awesome.min.css\" rel=\"external nofollow\" rel=\"stylesheet\" type=\"text/css\">
 <script src=\"<%=path %>/res/admin/js/jquery.min.js\"></script>
 <script src=\"<%=path %>/res/admin/js/bootstrap.min.js\"></script>
 <link href=\"<%=path %>/res/admin/jquery-select2/3.4/select2.css\" rel=\"external nofollow\" rel=\"stylesheet\" type=\"text/css\" /> 
 <script src=\"<%=path %>/res/admin/jquery-select2/3.4/select2.min.js\"></script>
 <script src=\"<%=path %>/res/admin/jquery-select2/3.4/select2_locale_zh-CN.js\"></script>
 
 <script type=\"text/javascript\" src=\"<%=basePath%>res/admin/js/layer/layer.js\"></script>
 <script type=\"text/javascript\">
  $(document).ready(function (){//加载页面时执行select2
   $(\"select\").select2();
   //弹出导出窗口
   $(\"#btnImport\").click(function(){
    var importStallId = $(\"#stallId option:selected\").val();
    var importCompanyId = $(\"#companyId option:selected\").val();
    $(\"#importCompanyId\").val(importCompanyId);
    $(\"#importStallId\").val(importStallId);
    if(importStallId==null || importStallId==\"\"){
     alert(\"请选择档口\");
    }else{
     layer.open({
      type: 1,
      skin: \'layui-layer-rim\', //加上边框
      area: [\'600px\', \'350px\'], //宽高
      content: $(\'#importBox\')
     });
    }
   });
  });

3 下面是后台代码Action 类

一:下载模板代码

/**
  * 下载模板
  * @throws IOException 
  */
 public void exportOrder() throws IOException{
  HttpServletRequest request = ServletActionContext.getRequest();
  HttpServletResponse response = ServletActionContext.getResponse();
  File file = null;
  InputStream inputStream = null;
  ServletOutputStream out = null;
  try {
   request.setCharacterEncoding(\"UTF-8\");
   String realPath = ServletActionContext.getServletContext().getRealPath(\"/\");
   file = new File(realPath+\"WEB-INF/mailtemplate/dishes.xlsx\");
   inputStream = new FileInputStream(file);
   response.setCharacterEncoding(\"utf-8\");
   response.setContentType(\"application/msexcel\");
   response.setHeader(\"content-disposition\", \"attachment;filename=\"
     + URLEncoder.encode(\"菜品导入\" + \".xlsx\", \"UTF-8\"));
   out = response.getOutputStream();
   byte[] buffer = new byte[512]; // 缓冲区
   int bytesToRead = -1;
   // 通过循环将读入的Excel文件的内容输出到浏览器中
   while ((bytesToRead = inputStream.read(buffer)) != -1) {
    out.write(buffer, 0, bytesToRead);
   }
   out.flush();
  } catch (Exception e) {
   e.printStackTrace();
  } finally {
   if (inputStream != null)
    inputStream.close();
   if (out != null)
    out.close();
   if (file != null)
    file.delete(); // 删除临时文件
  }
 }

二: 导入代码

/**
  * 导入
  * @throws IOException 
  */
 public void importExcel() throws IOException {
  List<Dishes> dishesList = getDishesList(file);
  if(dishesList !=null && dishesList.size()>0){
   for(Dishes dishes : dishesList){
    targetService.add(dishes);
   }
  }
  String basePath = ServletActionContext.getServletContext().getContextPath();
  ServletActionContext.getResponse().sendRedirect(basePath + \"/book/dishes/backstageversion/list\");
 }
 /**
  * 读取Excel数据 
  * @param filePath
  * @return List
  * @throws IOException
  */
 private List<Dishes> getDishesList(String filePath) throws IOException {
  XSSFWorkbook workBook= null;
  InputStream is = new FileInputStream(filePath);
  try {
   workBook = new XSSFWorkbook(is);
  } catch (Exception e) {
   e.printStackTrace();
  }
  Dishes dishes=null;
  List<Dishes> dishesList = new ArrayList<Dishes>();
  //循环工作表sheet
  //List<XSSFPictureData> picturesList = getPicturesList(workBook);//获取所有图片
  for(int numShett = 0;numShett<workBook.getNumberOfSheets();numShett++){
   XSSFSheet sheet = workBook.getSheetAt(numShett);
             //调用获取图片             Map<String, PictureData> pictureDataMap = getPictureDataMap(sheet, workBook);
if(sheet==null){
    continue;
   }
   //循环Row
   for(int rowNum=1;rowNum<=sheet.getLastRowNum();rowNum++){
    Row row = sheet.getRow(rowNum);
    if(row==null){
     continue;
    }
    
    dishes = new Dishes();
    //Cell
    Cell dishesName = row.getCell(0);
    if(dishesName==null){
     continue;
    }
    dishes.setName(getValue(dishesName));//菜品名称
    Cell price = row.getCell(1);
    if(price==null){
     continue;
    }
    dishes.setPrice(Double.parseDouble(getValue(price)));//优惠价格
    Cell oldPrice = row.getCell(2);
    if(oldPrice==null){
     continue;
    }
    dishes.setOldPrice(Double.parseDouble(getValue(oldPrice)));//原价格
    Cell summary = row.getCell(3);
    if(summary==null){
     continue;
    }
    dishes.setSummary(getValue(summary));//菜品描述
    Cell online = row.getCell(4);
    if(online==null){
     continue;
    }
    dishes.setOnline(Integer.parseInt(getValue(online)));//是否上下架
    Cell packCharge = row.getCell(5);
    if(packCharge==null){
     continue;
    }
    dishes.setPackCharge(Double.parseDouble(getValue(packCharge)));//打包费
    Cell stockNumber = row.getCell(6);
    if(stockNumber==null){//库存为必填
     continue;
    }
    dishes.setStockNumber(Integer.parseInt(getValue(stockNumber)));//每餐库存
    Cell immediateStock = row.getCell(7);
    if(immediateStock==null){//当前库存
     continue;
    }
    dishes.setImmediateStock(Integer.parseInt(getValue(immediateStock)));//当前库存
    Cell purchaseLimit = row.getCell(8);
    if(purchaseLimit==null){
     continue;
    }
    dishes.setPurchaseLimit(Integer.parseInt(getValue(purchaseLimit)));//限购数量
    Cell restrictionType = row.getCell(9);
    
    if(restrictionType==null){
     continue;
    }
    dishes.setRestrictionType(Integer.parseInt(getValue(restrictionType)));//限购方式
    Cell sort = row.getCell(10);
    if(sort==null){
     continue;
    }
    dishes.setSort(Integer.parseInt(getValue(sort)));//排序
    Cell contents = row.getCell(11);
    if(contents==null){
     continue;
    }
    dishes.setContents(getValue(contents));//菜品详情
    dishes.setCreateTime(new Date());
    Company company = companyService.load(importCompanyId);
    Stall stall = stallService.load(importStallId);
    dishes.setCompany(company);
    dishes.setStall(stall);

                 //set 图片                 PictureData pictureData = pictureDataMap.get(rowNum+\"\");                 if(pictureData !=null){                  String upImageUrl = UpImage(pictureData.getData());                  dishes.setImage(upImageUrl);                 }
    dishesList.add(dishes);
   }
  }
  return dishesList;
 }
 /**
  * 得到Excel表中的值
  * @param hssfCell
  * @return String
  */
 @SuppressWarnings(\"unused\")
 private String getValue(Cell cell){
  DecimalFormat df = new DecimalFormat(\"###################.###########\");
  if(cell.getCellType()==cell.CELL_TYPE_BOOLEAN){
   return String.valueOf(cell.getBooleanCellValue());
  }
  if(cell.getCellType()==cell.CELL_TYPE_NUMERIC){
   return String.valueOf(df.format(cell.getNumericCellValue()));
  }else{
   return String.valueOf(cell.getStringCellValue());
  }
 }

4 get set 方法

 private String file;
 
 private Long importCompanyId;
 private Long importStallId;
public String getFile() {
  return file;
 }

 public void setFile(String file) {
  this.file = file;
 }

 public Long getImportCompanyId() {
  return importCompanyId;
 }

 public void setImportCompanyId(Long importCompanyId) {
  this.importCompanyId = importCompanyId;
 }

 public Long getImportStallId() {
  return importStallId;
 }

 public void setImportStallId(Long importStallId) {
  this.importStallId = importStallId;
 }

公司需求改变要增加导入图片到又拍云服务器,所以下面增加读取excel图片

/**
  * 读取Excel 中图片
  * @param sheet
  * @param workBook
  * @return
  */
 private Map<String, PictureData> getPictureDataMap(XSSFSheet sheet,XSSFWorkbook workBook){
  Map<String, PictureData> map = new HashMap<String,PictureData>();
  for(POIXMLDocumentPart dr : sheet.getRelations()){
   if(dr instanceof XSSFDrawing){
    XSSFDrawing drawing = (XSSFDrawing) dr;
    List<XSSFShape> shapesList = drawing.getShapes();
    if(shapesList !=null && shapesList.size()>0){
     for(XSSFShape shape : shapesList){
      XSSFPicture pic = (XSSFPicture) shape;
      XSSFClientAnchor anchor = pic.getPreferredSize();
      CTMarker cTMarker = anchor.getFrom();
      String picIndex = cTMarker.getRow()+\"\";
      map.put(picIndex, pic.getPictureData());
     }
    }
   }
  }
  return map;
 }
/**
  * 上传图片到又拍云
  * @param bytes
  * @return
  */
 private String UpImage(byte[] bytes){
  String fileName = UUID.randomUUID().toString() + \".jpg\";
  String uploadURL = UpYunClient.upload(fileName, bytes);
  return uploadURL;
 }

注意:请用Poi  jar 3.9 版本 不然读取图片代码会报错

以上就是java 使用poi 导入Excel 数据到数据库的步骤的详细内容,更多关于Java 导入Excel 数据到数据库的资料请关注自学编程网其它相关文章!

遇见资源网 JAVA java 使用poi 导入Excel数据到数据库的步骤 http://www.ox520.com/20263.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务