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

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

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

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 数据到数据库的资料请关注我们其它相关文章!

(0)

相关推荐

  • java 使用poi动态导出的操作

    实现用户想要那个字段的数据,就导出那个字段的数据,我使用#分割字段实现 在传入字段的值时做文章 创建一个excel导出工具类, package com.zy.util; import java.io.OutputStream; import java.lang.reflect.Method; import java.util.Collection; import java.util.Iterator; import javax.servlet.http.HttpServletResponse;

  • Java中利用POI优雅的导出Excel文件详解

    前言 故事是这样开始的: 公司给排了几天的工期,让完成 2 个功能模块的开发.其中有一个场景是这样的,从 Excel 导入数据,要求数据不能重复.用户可以下载导入失败的 Excel 文件. 这样就有 2 种实现 将失败数据存储数据库,需要下载时生成 Excel 下载即可 将失败数据生成 Excel 文件存储文件服务器,然后返回下载链接. 老大要求按方案二进行.好吧,导出 Excel 是再常见不过的功能了,然而总是觉得以前写的不够优雅,所以决定进行简单的封装,以适应简单场景的 Excel 导出.

  • Java Poi 在Excel中输出特殊符号的实现方法

    最近的工作围绕报表导出,并没有集成相应的报表插件,只是使用了Poi.其中有一个需求,Excel中导出特殊符号,如√.×等.在网上找寻了许久,没有相关资料,故记录分享一下. 思考良久,走了不少弯路,最后受 System.out.println() 启发,实现方式真的超级简单.每一个特殊符号,都对应一个Unicode编码,我们只需要将特定的符号,转变成Unicode编码,进行输出即可. 相应的代码输出: cell.setCellValue("\u221A"); 另附自己编写的Excel工具

  • java利用POI读取excel文件的方法

    摘要:利用java读取excel文件,读取文件并获取文件中每一个sheet中的值. 一.需要提前导入的包: import java.io.File; import java.io.FileInputStream; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook

  • Java使用poi组件导出Excel格式数据

    在做管理系统的时候,我想Excel的导出是我们很难规避掉的,而且这也是个很实用很人性化的功能. Java中对于Excel的支持有很多种,比如说JXL,POI等.我这边使用的是POI进行一个Excel的操作,下面我会简单分享下POI组件的使用,以及我使用比较多一个工具类. POI组件 poi组件是由Apache提供的组件包,主要职责是为我们的Java程序提供对于office文档的相关操作.本文主要是它对于Excel操作的一个介绍. 官方主页:http://poi.apache.org/index.

  • Java实现导入导出Excel文件的方法(poi,jxl)

    目前,比较常用的实现Java导入.导出Excel的技术有两种Jakarta POI和Java Excel直接上代码: 一,POI POI是apache的项目,可对微软的Word,Excel,Ppt进行操作,包括office2003和2007,Excl2003和2007.poi现在一直有更新.所以现在主流使用POI. xls: pom: <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi

  • 详解Java中NullPointerException异常的原因详解以及解决方法

    NullPointerException是当您尝试使用指向内存中空位置的引用(null)时发生的异常,就好像它引用了一个对象一样. 当我们声明引用变量(即对象)时,实际上是在创建指向对象的指针.考虑以下代码,您可以在其中声明基本类型的整型变量x: int x; x = 10; 在此示例中,变量x是一个整型变量,Java将为您初始化为0.当您在第二行中将其分配给10时,值10将被写入x指向的内存中. 但是,当您尝试声明引用类型时会发生不同的事情.请使用以下代码: Integer num; num

  • Java如何利用POI读取Excel行数

    这篇文章主要介绍了java如何利用POI读取Execel行数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 java 利用poi 读excel文件的操作,读取总的数据行数一般是通过调用 sheet.getLastRowNum() ;可是这样有时候会出现一些问题,例如,当其中一行的数据的确都为空,可是其原本的格式还在,并没有连带删除,这样计算出来的行数就不真实(比真实的大),还有当出现空白行时(也即某一行没有任何数据,通过Row row = sh

  • Java 使用poi把数据库中数据导入Excel的解决方法

    Java 利用poi把数据库中数据导入Excel 效果: 使用时先把poi包导入工程的path,注意只需要导入poi包即可,下载后有三个jar包 核心代码: 连接数据库:DBConnection.java 复制代码 代码如下: package org.xg.db;import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.ResultSet;i

  • Java POI读取excel中数值精度损失问题解决

    描述: excel 单元格中,纯数字的单元格,读取后 后面会加上 .0 . 例如: 1 --> 1.0 而使用下面的方法,可能会对小数存在精度损失 cell.setCellType(CellType.STRING); //读取前将单元格设置为文本类型读取 例如: 2.2 --> 2.1999999997 目前的解决办法: 一. 将excel单元格改为文本类型 注意,直接修改单元格属性不管用, 使用 分列 的方式,可以实现将数值改为文本类型. 二. java处理 public class Com

  • java基于poi导出excel透视表代码实例

    这篇文章主要介绍了java基于poi导出excel透视表代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 从前,我是一个前端程序猿,怀着对打通任(前)督(后)二(开)脉(发)的梦想转了后端,自学两礼拜java+spring全家桶,直接上项目实战.最近接到一需求:将业务数据导出一张透视表. 需求开发完成已近有一段时间了,甲方的大爷大妈,爷爷奶奶们也都用的很开心,我也很开心,于是就心想咱学了也不能白学,所以写下这篇随笔. 先看下用easypo

随机推荐