excel导出导入通用方法
/**
* 方法说明:批量导出通用方法
* 创建时间:2018年8月24日 ***
* @param filePath 文件地址
* @param sheetName 分页名称
* @param title Excel文件表头(各个属性中文名称)
* @param propertys 导出数据对象实体类的属性名称,首字母大写
* @param conList 导出的数据集合
* @return
*/
public static boolean exportExcel(String filePath, String sheetName, String[] title, String[] propertys, List<Object> conList) {
try {
if (title != null && title.length > 0 && sheetName != null && !"".equals(sheetName)) {
// 导出excel标题
// String[] title = { "基础基地课堂教学质量评价计算", "序号", "姓名", "职务", "系部", "教研室", "领导评价成绩", "同行评价成绩", "专家评价成绩", "学员评价成绩", "最终成绩", "评价档次"};
// 创建成成excel工具类
WritableWorkbook wwb;
// 获取输出流
OutputStream os = new FileOutputStream(filePath);
wwb = Workbook.createWorkbook(os);
// 生成excel文件wwb.createSheet(excel文件名, 第几页);
WritableSheet sheet = wwb.createSheet(sheetName, 0);
// Label是单元格内容的Model
Label label = null;
// jxl 是专门操作excel的工具类
jxl.write.WritableFont wfont = new jxl.write.WritableFont(WritableFont.createFont("微软雅黑"), 16);
// 生成一种字体
WritableCellFormat font = new WritableCellFormat(wfont);
// 字体水平居中
font.setAlignment(jxl.format.Alignment.CENTRE);
// 字体垂直居中
font.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);
// 自动换行
font.setWrap(true);
// sheet操作列的属性
// 合并单元格 sheet.mergeCells(第几类,第几格,到第几列,到第几格)
sheet.mergeCells(0, 0, title.length-2, 0);
// 单元格行高
sheet.setRowView(0, 750);
// 创建label,给其内容
label = new Label(0, 0, title[0], font);
// 写进excel
sheet.addCell(label);
for (int i = 1; i < title.length; i++) {
sheet.setRowView(i, 800);
sheet.setColumnView(0, 8);
sheet.setColumnView(i, 24);
label = new Label(i - 1, 1, title[i], font);
sheet.addCell(label);
}
wfont = new jxl.write.WritableFont(WritableFont.createFont("楷体"), 12);
font = new WritableCellFormat(wfont);
font.setAlignment(jxl.format.Alignment.CENTRE);
font.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);
font.setWrap(true);
if (conList != null && conList.size() > 0) {
int j = 2;
for (int i = 0; i < conList.size(); i++) {
Object tr = conList.get(i);
if (tr != null) {
sheet.setRowView(j, 800);
sheet.setColumnView(0, 8);
sheet.setColumnView(i + 1, 24);
label = new Label(0, j, j - 1 + "", font);
sheet.addCell(label);
for (int l = 0; l < propertys.length; l++) {
label = new Label(l+1, j, (String) tr.getClass().getMethod("get" + propertys[l]).invoke(tr), font);
sheet.addCell(label);
}
j++;
}
}
}
SheetSettings setting = sheet.getSettings();
// 页边距start
setting.setTopMargin(0.0);
setting.setLeftMargin(0.5);
setting.setRightMargin(0.0);
setting.setBottomMargin(0.0);
// 页边距end
// 写入数据
wwb.write();
// 关闭文件
wwb.close();
return true;
}
} catch (Exception e) {
System.out.println("writeExcelForDoc1---出现异常---");
e.printStackTrace();
}
return false;
}
/**
*
* 方法说明:
* 创建时间:2018年8月24日 (***)
* @param excelPath 文件地址
* @param obj 要导入的数据实体类
* @param propertys 要导入的字段 字符串名称数组 首字母大写
* @param nameCodeMap Map<导入字段,Map<导入内容,转义信息>> 例: Map<性别,Map<男,"1">>
* @param outMap 非必填字段
* @return
*/
public static List<Object> uploadExcel(String excelPath, Object obj, String[] propertys, Map<String,Map<String,String>> nameCodeMap, Map<String,String> outMap) {
try {
File file = new File(excelPath);
Workbook book = Workbook.getWorkbook(file);
List<Object> tempList = new ArrayList<Object>();
Sheet[] sheets = book.getSheets();
for (Sheet sheet : sheets) {
// 获得第一个工作表对象
// Sheet sheet = book.getSheet(0);
if (sheet!= null && obj!=null) {
int columnum = sheet.getColumns();// 得到列数
int rownum = sheet.getRows();// 得到行数
for (int i = 2; i < rownum; i++) {
boolean bRet3 = false;
Cell cellFirst = sheet.getCell(0, i);
String resultFirst = cellFirst.getContents();
if(resultFirst==null || "".equals(resultFirst)){
continue;
}
for (int j = 1; j < columnum; j++) {
// 得到第一列第一行的单元格
Cell cell1 = sheet.getCell(j, i);
String result = cell1.getContents();
result = result.trim();
if ("".equals(result) || result==null) {
if("1".equals(outMap.get(propertys[(j-1)]))){
continue;
}else{
break;
}
}else{
bRet3 = true;
if(nameCodeMap!=null && nameCodeMap.size()>0 && nameCodeMap.get(propertys[(j-1)])!=null && !"".equals(nameCodeMap.get(propertys[(j-1)]))){
String value = nameCodeMap.get(propertys[(j-1)]).get(result);
if(value!=null && !"".equals(value)){
obj.getClass().getMethod("set"+propertys[(j-1)],String.class).invoke(obj, value);
}
}else if("-".equals(result) || "无".equals(result) || "空".equals(result)){
obj.getClass().getMethod("set"+propertys[(j-1)],String.class).invoke(obj, "");
}else{
obj.getClass().getMethod("set"+propertys[(j-1)],String.class).invoke(obj, result);
}
}
}
if (bRet3) {
tempList.add(obj);
obj = obj.getClass().getMethod("initThisObj").invoke(obj);
}else{
book.close();
return null;
}
}
}
}
book.close();
file = null;
// System.out.println("tempList:"+tempList);
// Excel里面有数据才会加到集合里,没有返回空集合
return tempList;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
excel导出导入通用方法的更多相关文章
- ORACLE使用EXPDP和IMPDP数据泵进行导出导入的方法
ORACLE使用EXPDP和IMPDP数据泵进行导出导入的方法 (2010-05-28 12:54:34) http://blog.sina.com.cn/s/blog_67d41beb0100ixn ...
- 不同版本的SQL Server之间数据导出导入的方法及性能比较
原文:不同版本的SQL Server之间数据导出导入的方法及性能比较 工作中有段时间常常涉及到不同版本的数据库间导出导入数据的问题,索性整理一下,并简单比较下性能,有所遗漏的方法也欢迎讨论.补充. 0 ...
- 使用NPOI组件完成的Excel导出导入(附源代码,测试通过)
最近遇到一个Excel导入导出的问题,要支持winform和webform,这里我是一个认真严谨的coder,所以决定把这个记录下来!和大家一起分享一下!如果需要的同学可以下载哦! 对于NPOI这个组 ...
- Mysql 用命令行导出导入数据方法
方法一: 导出参考:https://www.cnblogs.com/activiti/p/6700044.html 用mysqldump可以导出整个数据库里的表和数据,不单单是只导出某个表的数据 命令 ...
- excel 导出导入
/** * 导出 * @param * @param * @return */ public function exportexcel() { set_time_limit(0); ini_set(' ...
- C#Excel导出导入
using System; using System.Collections.Generic; using NPOI; using NPOI.HPSF; using NPOI.HSSF; using ...
- Oracle导出/导入数据方法--两种方法(pde格式/dmp格式)
转至:https://www.cnblogs.com/houbxblogs/articles/13365557.html?ivk_sa=1024320u 1.导出数据方法一(pde格式) 工具→ 导出 ...
- 【Oracle】EXPDP和IMPDP数据泵进行导出导入的方法
一.expdp/impdp和exp/imp 客户端工具 1.exp和imp是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用. 服务端工具 2.expdp和impdp是服务端的工具程序,他们 ...
- php 之 excel导出导入合并
<?php class Excel extends Controller { //直属高校 public function __construct() { parent::Controller( ...
随机推荐
- 三、数据API-3
预备 返回格式需要包括: // Code 状态码(200,400等) // Msg 提示信息(邮箱格式不正确:数据返回成功等) // Result 返回数据 一.WebAPI与传统MVC的区别是 MV ...
- 【XSY3141】哲学家 计算几何 线段树
题目描述 有一个平面,最开始平面上没有任何点. 你要按顺序加入 \(n\) 个点,求加入每个点后有多少三角形严格包含原点(在边界上不算). \(n\leq 400000\),无重点. 题解 其实这题本 ...
- Tensor是神马?为什么还会Flow?
https://baijiahao.baidu.com/s?id=1568147583188426&wfr=spider&for=pc 也许你已经下载了TensorFlow,而且准备开 ...
- usb的hid鼠标键盘报告描述符(五)
title: usb的hid鼠标键盘报告描述符 tags: linux date: 2018/12/20/ 18:05:08 toc: true --- usb的hid鼠标键盘报告描述符 https: ...
- 分布式监控系统开发【day37】:需求讨论(一)
本节内容 为什么要做监控? 常用监控系统设计讨论 监控需求讨论 如何实现监控服务器的水平扩展? 监控系统架构设计 一.为什么要做监控? 熟悉IT监控系统的设计原理 开发一个简版的类Zabbix监控系统 ...
- Spring的事务机制
---恢复内容开始--- 内定的=>(只需要在xml 中添加一个bean) 在xml 中添加 <bean id="listener" class="com.t ...
- 第二十三节: EF性能篇(三)之基于开源组件 Z.EntityFrameWork.Plus.EF6解决EF性能问题
一. 开篇说明 EF的性能问题一直以来经常被人所吐槽,究其原因在于“复杂的操作在生成SQL阶段耗时长,且执行效率不高”,但并不是没有办法解决,从EF本身举几个简单的优化例子: ①:如果仅是查询数据,并 ...
- PLSQL Developer 远程连接Oracle数据库
下载.安装.激活PLSQL Developer,本例使用 PLSQL Developer 13 (64 bit). 下载Oracle即时客户端 Instant Client,本例使用11gR2 链接: ...
- CSS难点 为什么height设置100%会失效,分栏目等高布局(高度自适用布局)的实现方案
前言 相信在平时写CSS的时候大家都或多或少遇见过设置了height为百分比的时候发现不起作用.今天我们就来一探究竟 原因:父元素未设置具体高度,子元素设置height:100%是无效的. 现象以及方 ...
- free命令查看内存信息
free介绍 FREE(1) Linux User’s Manual FREE(1) NAME free - Display amount of free and used memory in the ...