java操作poi生成excel.xlsx(设置下拉框)下载本地和前端下载
需求:导入excel表格,如果excel有错误,将错误的地方标红,在把数据以excel的形式写出,供用户下载
解决方案:1.以实体类的方式接收excel并解析(创建两个集合一个接收正常的数据一个接收错误的数据)
2.错误集合无论正确错误数据都要存储,并记录是否有误(错误数据拼接特殊字符作为标记,然后记录写入集合)
3.如果发现记录有错误记录,就要使用错误数据集合生成excel(对错误的数据对特殊字符截取)
4.将错误的excel生成到工程的相对的路径下,也可以上传服务器更好(下次下载前要记得清理记录),返回前端一个地址,前端点击链接进行下载
5.下面是片段代码
public static SXSSFWorkbook createExportInterviewExcel(List<Operator> data, String sheetName) {
SXSSFWorkbook sxssfWorkbook = new SXSSFWorkbook(100);
//标题栏设置
CellStyle style = sxssfWorkbook.createCellStyle();
style.setWrapText(true);//自动换行
style.setVerticalAlignment(CellStyle.VERTICAL_CENTER);//垂直居中
style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 居左
Font font = sxssfWorkbook.createFont();
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); //字体增粗
style.setFont(font);
DataFormat formats = sxssfWorkbook.createDataFormat();
style.setDataFormat(formats.getFormat("@"));//设置文本格式
//正常格式设置
CellStyle cellStyle = sxssfWorkbook.createCellStyle();
//cellStyle.setWrapText(true);//自动换行
cellStyle.setVerticalAlignment(CellStyle.VERTICAL_CENTER);//垂直居中
cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 居左
DataFormat format = sxssfWorkbook.createDataFormat();
cellStyle.setDataFormat(format.getFormat("@"));//设置文本格式
Sheet taskInfoSheet = sxssfWorkbook.createSheet(sheetName);
DataValidationHelper helper = taskInfoSheet.getDataValidationHelper();//设置下拉框xlsx格式
//设置列宽
taskInfoSheet.setColumnWidth(5, 256 * 21);
taskInfoSheet.setColumnWidth(6, 256 * 15);
taskInfoSheet.setColumnWidth(7, 256 * 15);
taskInfoSheet.setColumnWidth(8, 256 * 20);
taskInfoSheet.setColumnWidth(18, 256 * 20);
// 第一行标题
Row row_tital = taskInfoSheet.createRow(0);
String[] keyWord = {"姓名","性别","民族", "年龄", "学历", "身份证号", "手机号",
"在我司任职过", "岗位名", "广告名", "部门","工作地", "推荐人","推荐人电话","推荐人部门","推荐人工号", "面试安排时间","是否录用", "淘汰类型", "淘汰原因"};
for (int i = 0; i < keyWord.length; i++) {
Cell cell_tital_index = row_tital.createCell(i);
cell_tital_index.setCellValue(keyWord[i]);
cell_tital_index.setCellStyle(style);
}
//异常情况处理
if (CollectionUtils.isEmpty(data) ||(CollectionUtils.isNotEmpty(data) && StringUtils.isBlank(data.get(0).getName()))) {
return sxssfWorkbook;
}
// 数据行
for (int i = 0; i < data.size(); i++) { // 导出详情
Row row_data = taskInfoSheet.createRow(i + 1);
Cell cell_data_name = row_data.createCell(0);
cell_data_name.setCellValue(data.get(i).getName());
cell_data_name.setCellStyle(cellStyle);
Cell cell_data_nation = row_data.createCell(1);
cell_data_nation.setCellValue(data.get(i).getNational());
cell_data_nation.setCellStyle(cellStyle);
Cell cell_data_age = row_data.createCell(2);
Integer age= null;
if(data.get(i).getAge()!= null){
age = data.get(i).getAge();
}else{
age=1;
}
cell_data_age.setCellValue(age);
cell_data_age.setCellStyle(cellStyle);
//添加工作地
Cell cell_data_location =row_data.createCell(3);
cell_data_location.setCellValue(data.get(i).getLocation());
cell_data_location.setCellStyle(cellStyle);
Cell cell_data_referrer = row_data.createCell(4);
cell_data_referrer.setCellValue(data.get(i).getReferrer());
cell_data_referrer.setCellStyle(cellStyle);
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
String interviewTime = "";
if (null != data.get(i).getInterviewTime()) {
interviewTime = sdf.format(data.get(i).getInterviewTime());
}
Cell cell_data_interviewTime = row_data.createCell(5);
cell_data_interviewTime.setCellValue(interviewTime);
cell_data_interviewTime.setCellStyle(cellStyle);
String[] yesOrNo = {"是", "否"};
creatDropDownList(taskInfoSheet,helper,yesOrNo,1,200,6,6);
String[] list = {"不符合返聘要求", "不符合公司规则", "综合素质", "其他"};
creatDropDownList(taskInfoSheet, helper, list, 1, 200, 7, 7);
}
return sxssfWorkbook;
}
//创建下拉框
private static void creatDropDownList(Sheet taskInfoSheet, DataValidationHelper helper, String[] list,
Integer firstRow, Integer lastRow, Integer firstCol, Integer lastCol) {
CellRangeAddressList addressList = new CellRangeAddressList(firstRow, lastRow, firstCol, lastCol);
//设置下拉框数据
DataValidationConstraint constraint = helper.createExplicitListConstraint(list);
DataValidation dataValidation = helper.createValidation(constraint, addressList);
//处理Excel兼容性问题
if (dataValidation instanceof XSSFDataValidation) {
dataValidation.setSuppressDropDownArrow(true);
dataValidation.setShowErrorBox(true);
} else {
dataValidation.setSuppressDropDownArrow(false);
}
taskInfoSheet.addValidationData(dataValidation);
}
//需求:导入excel表格,如果excel有错误,将错误的地方标红,在把数据以excel的形式写出,供用户下载
//解决方案:1.以实体类的方式接收excel并解析(创建两个集合一个接收正常的数据一个接收错误的数据)
//2.错误集合无论正确错误数据都要存储,并记录是否有误(错误数据拼接特殊字符作为标记,然后记录写入集合)
//3.如果发现记录有错误记录,就要使用错误数据集合生成excel(对错误的数据对特殊字符截取)
//4.将错误的excel生成到工程的相对的路径下(下次下载前要记得清理记录),返回前端一个地址,前端点击链接进行下载
//这个方法就是清除之前的文件夹
private String getExportResult(SXSSFWorkbook sxssfWorkbook) {
//删除之前文件夹下的文件
String targetUrl = System.getProperty("export.error.result");
File targetFile = new File(targetUrl);
ContentUtil.deletAllFiles(targetFile);
String fileName = null;
try {
fileName = System.getProperty("export.error.result") + UUID.randomUUID().toString() + ".xlsx";
File file = new File(fileName);
if (!file.exists()) {
file.getParentFile().mkdirs();
}
FileOutputStream outputStream = new FileOutputStream(fileName);
sxssfWorkbook.write(outputStream);
outputStream.close();
} catch (IOException e) {
logger.error("OperatorInfoImportAuditResultServiceImpl下载导入错误excel表格异常", e);
e.printStackTrace();
}
return fileName;
}
public static void deletAllFiles(File file) {
if (file == null) {
return;
}
if (file.exists()) {
if (file.isFile()) {
file.delete();
}else if (file.isDirectory()) {
File[] listFiles = file.listFiles();
if (listFiles == null) {
return;
}
for (File file2 : listFiles) {
deletAllFiles(file2);
}
/* //递归跳出来的时候删除空文件夹
file.delete();*/
}
}
}
@RequestMapping(value = "/exportErrorImportResult", method = RequestMethod.GET)
public void exportErrorImportResult(@RequestParam(value = "paramUrl") String paramUrl, HttpServletResponse response, HttpServletRequest request) {
//生成错误的文档
try {
XSSFWorkbook workbook = null;
File file = new File(paramUrl);
if (file.exists()) {
FileInputStream in = new FileInputStream(file);
workbook = new XSSFWorkbook(in);
} else {
logger.info("初级员工内推导出错误的excel文件,文件不存在");
}
OutputStream ouputStream = response.getOutputStream();
String fileName = "导出错误";
fileName = URLEncoder.encode(fileName, "UTF-8");
response.reset();
response.setContentType("application/vnd.ms-excel");
response.setHeader("Content-Disposition", "attachment;filename=" + fileName + ".xlsx");
workbook.write(ouputStream);
ouputStream.flush();
ouputStream.close();
} catch (Exception e) {
logger.error("导出错误的excel文件,OperatorPostInfoController 异常:", e);
}
}
java操作poi生成excel.xlsx(设置下拉框)下载本地和前端下载的更多相关文章
- POI设置excel添加列下拉框
POI在生成excel模板时需要为列添加下拉框,我写了两个方法. @ 方法一:适用任何情况,不受下拉框值数量限制.但是需要通过引用其它列值. 思路大概如下: 1.创建一个隐藏的sheet页,用于存放下 ...
- poi生成excel整理(设置边框/字体/颜色/加粗/居中/)
转: poi生成excel整理(设置边框/字体/颜色/加粗/居中/) 2016年12月02日 11:05:23 吃奶的牛 阅读数:34324 HSSFWorkbook wb = new HSSFW ...
- Jquery动态设置下拉框selected --(2018 08/12-08/26周总结)
1.Jquery动态根据内容设置下拉框selected 需求就是根据下拉框的值动态的设置为selected,本以为很简单,网上一大推的方法,挨着尝试了之后却发现没有一个是有用的.网上的做法如下: &l ...
- js 设置下拉框的默认值
设置下拉框的默认值,直接在option中增加selected就可以了.但是现在要使用JS来设置它的默认值,代码如下: <select name="aaa" id=" ...
- jquery 根据后台传过来的值动态设置下拉框、单选框选中
更多内容推荐微信公众号,欢迎关注: jquery 根据后台传过来的值动态设置下拉框.单选框选中 $(function(){ var sex=$("#sex").val(); va ...
- 【WPF学习笔记】之如何设置下拉框读取SqlServer数据库的值:动画系列之(一)
先前条件:设置好数据库,需要三个文件CommandInfo.cs.DbHelperSQL.cs.myHelper.cs,需要修改命名空间,参照之前随笔http://www.cnblogs.com/Ow ...
- jquery设置下拉框selected不起作用
在js中设置下拉框被选中: 最初写法: //移出selected $("#selected option").removeAttr("selected"); / ...
- Java使用poi生成Excel,生成两种表格下拉框
想要使用POI操作以xsl结尾的Excel,首先要下载poi相关的jar包,用到的jar有: poi-3.9.jar poi-ooxml-3.9.jar poi-ooxml-schemas-3.9.j ...
- java使用poi生成excel
使用poi生成excel通常包含一下几个步骤 创建一个工作簿 创建一个sheet 创建一个Row对象 创建一个cell对象(1个row+1个cell构成一个单元格) 设置单元格内容 设置单元格样式. ...
随机推荐
- dedecms 多级栏目时,调用上级栏目名称和链接
{dede:field name='position' runphp='yes'} $tc="-"; //分隔符 $tw=$GLOBALS['cfg_list_symbol']; ...
- 黑客正在使用美国NSA泄露的工具进行挖矿
早些年我们知道美国国家安全局囤积不少漏洞准备自己使用,结果这些漏洞以及利用工具被方程式组织获得. 随后名为影子经纪人的黑客组织获得这些漏洞和工具后又再次出售,当初的永恒之蓝漏洞就是从这里泄露的. 永恒 ...
- 测试人员必备:linux文件清理不得不知道的技巧
测试人员最常见和繁琐的任务之一就是清理系统,比如防止磁盘空间出现不足.下面是我收集的一些常用的 Linux 文件系统相关命令. 一 检查可用空间 要查找服务器上所有文件系统上的可用空间,请执行以下命令 ...
- IANA
IANA,全称The Internet Assigned Numbers Authority,即互联网数字分配机构1. Internet已成为全球范围的网络.为保证其正常运作,全球有很多机构参与进来. ...
- selenium-Xpath使用方法
01:什么是Xpath Xpath是一门xml文档中查找信息的语言,Xpath可用来在xml文档中对元素和属性进行遍历,主流的浏览器都支持xpath,因为HTML页面在DOM中表示xhtml文档 xp ...
- noi.ac NA536 【打地鼠】
又一道可写的小清新思维题 其实想到倒着做了,然而还是因为T1害人不浅(我太菜了),所以并没有写 考虑两个局面不同,显然至少打了一次地鼠,基于操作的颜色覆盖性质,我们可以考虑把操作倒着做,对于一个X点, ...
- 【HDU6703】array
题目大意:给定一个 N 个数字的排列,需要支持两种操作:对某个位置的数字 + 1e7,查询区间 [1, r] 中最小的不等于区间中任何一个数字的数. 题解:本题证明了对于 50W 的数据来说,\(O( ...
- :last-child的坑-CSS3选择器
CSS3选择器之:last-child - Eric 真实经历 最近开发项目的时候发现了一个这么多年忽略的问题,和大家分享一下.项目使用的是Antd组件库,有一个搜索框是这样的: 为了保证下拉框的内容 ...
- 提取全局应用程序集中的dll
如何提取全局应用程序集中的dll GAC路径:C:\WINDOWS\assembly 在资源管理器中打开这个路径看到的东西不能复制,右键中也只有 “卸载” 和 “属性” 两个菜单. 在命令提示符下切换 ...
- autofs 自动挂载.
autofs 自动挂载. 操作环境:redhat 6 一.autofs 说明 自动挂载器是一个监视目录的守护进程,并在目标子目录被引用时,自动执行预定义的挂载 自动挂载器由autofs服务脚本管理 自 ...