使用 Excel 进行报表的导入导出,首先下载相关的 jar 和 excel util。

Excel Util 下载地址

引入依赖:

<!-- poi office -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.9</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.9</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml-schemas</artifactId>
<version>3.9</version>
</dependency>

把相应的 jar 和 util 类放到项目中就可以在需要打印出来的实体类的get方法加上注解@ExcelField

Excel 报表数据模板下载代码:

controller层:

/**
* 下载导入Excel表信息数据模板
*/
@RequiresPermissions("metermessage:meterMessage:view")
@RequestMapping(value = "import/template")
public String importFileTemplate(HttpServletResponse response, RedirectAttributes redirectAttributes, String houseType) {
try {
meterMessageService.importFileTemplate(response);
return null;
} catch (Exception e) {
addMessage(redirectAttributes, "导入模板下载失败!失败信息:" + e.getMessage());
}
return "redirect:" + Global.getAdminPath() + "/metermessage/meterMessage/?repage&houseType=" + houseType;
}

service层:

//Excel表信息数据模板
public void importFileTemplate(HttpServletResponse response) throws IOException {
String fileName = "Excel表信息数据导入模板.xlsx";
List<MeterMessage> list = Lists.newArrayList();
MeterMessage meter = new MeterMessage();
meter.setOfficeName("*****");
meter.setUnitNumber("1");
meter.setFloor("1");
meter.setRoomNumber("01");
meter.setMeterNo("001");
meter.setRate(new Double(10));
meter.setMeterTypeLabel("水表");
list.add(meter);
new ExportExcel("Excel表信息数据", MeterMessage.class, 2).setDataList(list).write(response, fileName).dispose();
}

Excel表信息导入代码:

controller层:

/**
* 导入Excel信息数据
*/
@RequiresPermissions("metermessage:meterMessage:edit")
@RequestMapping(value = "import", method = RequestMethod.POST)
public String importFile(MultipartFile file, RedirectAttributes redirectAttributes, String houseType) {
if (Global.isDemoMode()) {
addMessage(redirectAttributes, "演示模式,不允许操作!");
return "redirect:" + Global.getAdminPath() + "/metermessage/meterMessage/?repage&houseType=" + houseType;
}
try {
String message = meterMessageService.importFile(file);
addMessage(redirectAttributes, message);
} catch (Exception e) {
addMessage(redirectAttributes, "导入Excel信息失败!失败信息:" + e.getMessage());
}
return "redirect:" + Global.getAdminPath() + "/metermessage/meterMessage/?repage&houseType=" + houseType;
}

service层:


	//导入excel信息数据
@Transactional(readOnly = false)
public String importFile(MultipartFile file) throws Exception {
int successNum = 0;
int failureNum = 0;
int row = 3;
StringBuilder failureMsg = new StringBuilder();
ImportExcel ei = new ImportExcel(file, 1, 0);
List<MeterMessage> list = ei.getDataList(MeterMessage.class);
Map<String, Object> map = new HashMap<String, Object>();// 去重复查询用
for (int i = 0; i < list.size(); i++) {
MeterMessage meter = list.get(i); String officeName = meter.getOfficeName();
String unitNumber = meter.getUnitNumber();
String floor = meter.getFloor();
String roomNumber = meter.getRoomNumber();
String meterTypeLabel = meter.getMeterTypeLabel();
String meterNo = meter.getMeterNo();
Double rate = meter.getRate(); if (StringUtils.isNoneBlank(officeName)) {
if (!map.containsKey(officeName)) {
List<Office> officeList = officeDao.findOfficeByName(officeName);
if (officeList != null && officeList.size() > 0) {
meter.setOffice(officeList.get(0));
map.put(officeName, officeList.get(0));
} else {
failureMsg.append("<br/>第" + row + "行数据:小区' " + officeName
+ "' 不存在,请先去'平台设置-->单位管理'创建该小区 ;");
failureNum++;
}
} else {
meter.setOffice((Office) (map.get(officeName)));
}
} else {
failureMsg.append("<br/>第" + row + "行数据:小区 不可为空 ");
failureNum++;
} String officeId = meter.getOffice().getId();
if (StringUtils.isNoneBlank(officeId) && StringUtils.isNoneBlank(unitNumber) && StringUtils.isNoneBlank(floor) && StringUtils.isNoneBlank(roomNumber)) {
if(!map.containsKey(officeId+unitNumber+floor+roomNumber)) {
HouseInformation house = houseInformationDao.findHouseIdByCondition(officeId, unitNumber, floor, roomNumber);
if(house != null) {
meter.setHouse(house);
map.put(officeId+unitNumber+floor+roomNumber, house);
} else {
failureMsg.append("<br/>第" + row + "行数据:房屋' " + officeName
+ "' 不存在;");
failureNum++;
}
} else {
meter.setHouse((HouseInformation) (map.get(officeId+unitNumber+floor+roomNumber)));
}
} else {
failureMsg.append("<br/>第" + row + "行数据:房屋 不可为空 ");
failureNum++;
} if (StringUtils.isNoneBlank(meterTypeLabel)) {
if(!map.containsKey(meterTypeLabel)) {
String meterType = DictUtils.getDictValue(meterTypeLabel, "meter_type", "1");
if (StringUtils.isNoneBlank(meterType)) {
meter.setMeterType(meterType);
map.put(meterTypeLabel, meterType);
} else {
failureMsg.append("<br/>第" + row + "行数据:仪表类型 '" + meterTypeLabel
+ "' 不存在,请先去'平台设置-->系统设置-->字典管理'创建该仪表类型 ");
failureNum++;
}
} else {
meter.setMeterType((String)(map.get(meterTypeLabel)));
}
} else {
failureMsg.append("<br/>第" + row + "行数据:仪表类型 不可为空 ");
failureNum++;
} if (StringUtils.isNoneBlank(meterNo)) {
meter.setMeterNo(meterNo);
} else {
failureMsg.append("<br/>第" + row + "行数据:仪表编号 不可为空 ");
failureNum++;
} if (rate != null) {
meter.setRate(rate);
} else {
failureMsg.append("<br/>第" + row + "行数据:倍率 不可为空 ");
failureNum++;
} meter.preInsert();
row++;
} if (failureNum > 0) {
failureMsg.insert(0, ",失败 " + failureNum + " 条Excel信息,导入信息如下:");
} else {
try {
if (list != null && list.size() > 0) {
dao.insertMeterList(list);
successNum = list.size();
}
} catch (ConstraintViolationException ex) {
failureMsg.append("<br/>excel信息 导入失败:");
List<String> messageList = BeanValidators.extractPropertyAndMessageAsList(ex, ": ");
for (String message : messageList) {
failureMsg.append(message + "; ");
failureNum++;
}
} catch (Exception ex) {
failureNum++;
failureMsg.append("<br/>excel信息 导入失败:" + ex.getMessage());
}
}
return "已成功导入 " + successNum + " 条excel信息" + failureMsg;
}

关注公众号,分享干货,讨论技术

Excel 报表导入导出的更多相关文章

  1. java实现excel的导入导出(poi详解)[转]

    java实现excel的导入导出(poi详解) 博客分类: java技术 excel导出poijava  经过两天的研究,现在对excel导出有点心得了.我们使用的excel导出的jar包是poi这个 ...

  2. java 中Excel的导入导出

    部分转发原作者https://www.cnblogs.com/qdhxhz/p/8137282.html雨点的名字  的内容 java代码中的导入导出 首先在d盘创建一个xlsx文件,然后再进行一系列 ...

  3. WEB 报表导入导出操作

    /** * 报表导出 * @param response */ @RequestMapping("/stuExcel") @LogAnno(value="对学生数据进行了 ...

  4. C# excel文件导入导出

    欢迎关注微信公众号 C#编程大全 这里有更多入门级实例帮你快速成长 在C#交流群里,看到很多小伙伴在excel数据导入导出到C#界面上存在疑惑,所以今天专门做了这个主题,希望大家有所收获! 环境:wi ...

  5. excel的导入导出的实现

    1.创建Book类,并编写set方法和get方法 package com.bean; public class Book { private int id; private String name; ...

  6. c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出

    c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出 using NPOI.HSSF.UserModel;using NPOI.SS.UserModel;using S ...

  7. OpenXml Excel数据导入导出(含图片的导入导出)

    声明:里面的很多东西是基于前人的基础上实现的,具体是哪些人 俺忘了,我做了一些整合和加工 这个项目居于openxml做Excel的导入导出,可以用OpenXml读取Excel中的图片 和OpenXml ...

  8. NodeJs之EXCEL文件导入导出MongoDB数据库数据

    NodeJs之EXCEL文件导入导出MongoDB数据库数据 一,介绍与需求 1.1,介绍 (1),node-xlsx : 基于Node.js解析excel文件数据及生成excel文件. (2),ex ...

  9. PowerDesigner数据库设计PDM基于Excel的导入导出总结

    经常用到pdm来管理代码,一两张表,手写一下还凑合,一旦表多了,就慌了.于是,开始学习用vbs进行Excel的来快速导入导出操作PDM就变得很紧急了,搜罗了网络上的很多vbs脚本,各有各的优点,但对于 ...

随机推荐

  1. “Hello World!”团队第三周召开的第二次会议

    今天是我们团队“Hello World!”团队第三周召开的第二次会议.博客内容: 一.会议时间 二.会议地点 三.会议成员 四.会议内容 五.todo list 六.会议照片 七.燃尽图 一.会议时间 ...

  2. 互评Alpha版本 - Hello World团队项目空天猎

    在测评该项目时,我找到了Hello World!团队的git,并下载了相关文件以及阅读了程序运行说明. 如图所示,我下载了一个名为 SkyHunter1.0.rar 的压缩文件包,文件包内容如下: 根 ...

  3. 《DWZ笔记一》<select>动态联动菜单

    联动菜单,即组合框Combo box,在DWZ文档中对组合框combox的是这样描述的: 在传统的select 用class 定义:class=”combox”, html 扩展:保留原有属性name ...

  4. 1014C程序语法树

    程序:冒泡算法C程序 #include <stdio.h> main() { int i,j,temp; int a[10]; for(i=0;i<10;i++) scanf (&q ...

  5. 软工网络15团队作业4-DAY5

    每日例会 昨天的工作. 张陈东芳:界面排版优化 吴敏烽:界面排版优化 周汉麟:继续根据商品编号来获取商品资料方法调试 林振斌:继续输出最近浏览记录的方法调试 李智:界面排版优化 全体人员:界面优化,初 ...

  6. webpack打包多html开发案例新

    闲来无事在原来简单打包案例的基础上,参考vue-cli的打包代码,改为多文件打包. 区别于上篇文章<webpack打包多html开发案例>,此次打包根据开发的不同环节进行打包,也就是有开发 ...

  7. windows操作系统下载tomcat,并与eclipse进行整合

    进入Tomcat官网之后,在左边我们看到,Tomcat的有6,7,8这三个最流行的版本,我们可以点击进去下载想要的版本. 进入里面之后,可以看见有64位的和32位的,就看自己的电脑是多少位的了,如果电 ...

  8. delphi使用SQL的教程4(使用Params属性为参数赋值 )

    17.4.1 使用Params属性为参数赋值   TQuery部件具有一个Params属性,它们在设计时不可用,在程序运行过程中可用,并且是动态建立的,当为TQuery部件编写动态SQL 语句时, D ...

  9. jquery 添加与删除的规律 当要添加时候要定位到自己的父元素 当要删除时候 通过事件函数传入的this找到自己的父元素进行删除

    jquery 添加与删除的规律 当要添加时候要定位到自己的父元素  当要删除时候 通过事件函数传入的this找到自己的父元素进行删除

  10. 【bzoj4425】[Nwerc2015]Assigning Workstations分配工作站 贪心+堆

    题目描述 佩内洛普是新建立的超级计算机的管理员中的一员. 她的工作是分配工作站给到这里来运行他们的计算研究任务的研究人员. 佩内洛普非常懒惰,不喜欢为到达的研究者们解锁机器. 她可以从在她的办公桌远程 ...