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">下载模板</a>
</form>
</div>
<input id="btnImport" class="btn btn-default" type="button" value="导入"/></li>
下面是js
<!-- Bootstrap -->
<link href="<%=path %>/res/admin/css/bootstrap.min.css" rel="stylesheet" type="text/css" />
<link href="<%=path %>/res/admin/css/xy_css.css" rel="stylesheet" type="text/css">
<link href="<%=path %>/res/admin/css/font-awesome.min.css" 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="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 数据到数据库的更多相关文章
- 【转】 如何导入excel数据到数据库,并解决导入时间格式问题
在办公环境下,经常会用到处理excel数据,如果用写程序导入excel数据到数据库那就太麻烦了,涉及解析excel,还要各种格式问题,下面简单利用数据库本身支持的功能解决这类导入问题. 准备 创建表 ...
- Java 使用poi导入excel,结合xml文件进行数据验证的例子(增加了jar包)
ava 使用poi导入excel,结合xml文件进行数据验证的例子(增加了jar包) 假设现在要做一个通用的导入方法: 要求: 1.xml的只定义数据库表中的column字段,字段类型,是否非空等条件 ...
- JAVA通过poi对Excel数据在(jsp+ssh)环境下导入导出
POI的下载与安装 请到网站http://www.apache.org/dyn/closer.cgi/poi/右击超链接2.5.1.zip下载压缩包poi-bin-2.5.1-final-20040 ...
- .net导入excel数据到数据库中
在开发过程中我们经常面临着需要将数据导出或者导入到系统中,例如一些生产管理系统,项目管理系统等等都会有这样的需求: 将excel数据到系统中思路:获取excel中每一行的数据,然后存入集合中,批量添加 ...
- [Java] 高效快速导入EXCEL数据
需求1.高效率的以excel表格的方式导入多条数据.2.以身份证号为唯一标识,如果身份证号已存在,则该条数据不导入. 分析刚开始的时候是传统的做法,解析excel数据,获取单个对象,判断身份证是否已存 ...
- POI 导入excel数据自动封装成model对象--代码
所有的代码如下: import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; ...
- 导入excel数据到数据库
1.上传excel到服务器 jsp页面代码 <form action="actionname" method="post" id="form1& ...
- Java使用POI导入Excel异常Cannot get a text value from a numeric cell 解决
异常原因:Excel数据Cell有不同的类型,当我们试图从一个数字类型的Cell读取出一个字符串并写入数据库时,就会出现Cannot get a text value from a numeric c ...
- PHP 导入Excel数据 到数据库
/** * 导入excel * @throws \PHPExcel_Exception * @throws \PHPExcel_Reader_Exception */ public function ...
随机推荐
- springboot08(springmvc自动配置原理)
MVC WebMvcAutoConfiguration.java @ConditionalOnMissingBean(name = "viewResolver", value = ...
- C#中对虚拟属性和抽象属性的重写有什么异同
public abstract class A { //抽象属性不能有实现代码 public abstract strin ...
- CentOS7中Tomcat的安装和配置以及启动配置tomcat。启动过程中的易错点
Tomcat运行需要设置JRE目录,全局变量配置,请参见: Linux下JDK的安装和配置 当然也可以直接修改Tomcat的配置文件,请自行度娘 1.下载并解压 请先去官网找到需要下载的tom ...
- python闯关之路二(模块的应用)
1.有如下字符串:n = "路飞学城"(编程题) - 将字符串转换成utf-8的字符编码的字节,再将转换的字节重新转换为utf-8的字符编码的字符串 - 将字符串转换成gbk的字符 ...
- pyqt中定时器的使用
1.定义一个定时器函数 # 定时器 from PyQt5.QtCore import QTimer def timer_start(): timer = QTimer() # fun1是监听的函数,如 ...
- 【原】移动端vue页面点透事件 - 分析与解决
近期项目遇到了vue页面事件被带到下一个页面的问题,也就是我们常说的点透事件,主要表现在android机器上,花了不少时间折腾,简单做下总结~ vue页面之间的切换通过Vue Router的route ...
- Missing artifact com.alibaba:dubbo:jar:2.8.4 dubbo编译打包
由于maven中心仓库中没有dubbo2.8.4,所以需要到github中下载源码包自己编译. 1.下载dubbo,地址:https://github.com/dangdangdotcom/dubbo ...
- 动手动脑5JAVA项目中的常用的异常处理情况
Java异常处理的几个原则如下. (1)不要丢弃异常,捕获异常后需要进行相关处理.如果用户觉得不能很好地处理该异常,就让它继续传播,传到别的地方去处理,或者把一个低级的异常转换成应 ...
- tkinter学习(5)messagebox、pack、grid和place方法
1.messagebox信息弹出框 1.1 代码: import tkinter as tk #导出tk模块 import tkinter.messagebox #导出弹出信息框 #定义窗口.标题.大 ...
- 吴裕雄 python 机器学习——模型选择损失函数模型
from sklearn.metrics import zero_one_loss,log_loss def test_zero_one_loss(): y_true=[1,1,1,1,1,0,0,0 ...