一篇在一个Excel表中创建多个sheet的代码
package projectUtil; import org.apache.commons.lang3.StringUtils;
import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.ss.usermodel.HorizontalAlignment;
import org.apache.poi.ss.usermodel.VerticalAlignment; import java.util.List;
import java.util.Map; /**
* 创建Excel表
* @author tian
* @date 2019/3/2315:46
*/
public class WorkbookUtil {
private HSSFWorkbook workbook = new HSSFWorkbook();// 创建一个Excel文件 public HSSFWorkbook getWorkbook() {
return this.workbook;
} public HSSFSheet writeExcel(List<Map<String, Object>> list, List<String> head, String sheetName) {
HSSFSheet sheet;// 创建一个Excel的Sheet
if (!StringUtils.isBlank(sheetName)) {
sheet = workbook.createSheet(sheetName);// 创建一个Excel的Sheet
} else {
sheet = workbook.createSheet("Sheet");// 创建一个Excel的Sheet
}
HSSFRow row4 = sheet.createRow(0); HSSFCellStyle style4 = workbook.createCellStyle();
style4.setAlignment(HorizontalAlignment.CENTER);//水平居中
style4.setVerticalAlignment(VerticalAlignment.CENTER);//垂直居中
style4.setWrapText(true);//自动换行
style4.setAlignment(HorizontalAlignment.CENTER);//水平居中
style4.setVerticalAlignment(VerticalAlignment.CENTER);//垂直居中
HSSFFont font4 = workbook.createFont();
// font.setFontName("华文行楷");//设置字体名称
font4.setFontHeightInPoints((short) 12);//设置字号
// font4.setBold( true);
style4.setFont(font4);
for (int i = 0; i < head.size(); i++
) {
sheet.setColumnWidth(i, 20 * 256);
HSSFCell cell4_1 = row4.createCell(i);
cell4_1.setCellValue(head.get(i));
cell4_1.setCellStyle(style4);
}
for (int i = 0; i < list.size(); i++) {
HSSFRow row5 = sheet.createRow(i + 1);
for (int y = 0; y < head.size(); y++
) {
HSSFCell cell5_1 = row5.createCell(y);
cell5_1.setCellValue(list.get(i).get(head.get(y)) == null ? "" : list.get(i).get(head.get(y)) + "");
cell5_1.setCellStyle(style4);
} } return sheet;
} }
自己写的工具类,可以参考一下,如果有bug希望各位大侠指教。
List<Map<String, Object>> rows = new ArrayList<>();
List<Map<String, Object>> zifu = new ArrayList<>();
List<Map<String, Object>> yinhang = new ArrayList<>();
for (Map one : list) {
Integer state = (Integer) one.get("state");
Map<String, Object> reMap = new LinkedHashMap<>();
reMap.put("提现编号", one.get("id"));
reMap.put("用户ID", one.get("userId"));
reMap.put("用户名称", one.get("name"));
reMap.put("用户手机号", one.get("phone"));
reMap.put("银行卡户主名称", one.get("userName"));
reMap.put("银行", one.get("bankName"));
reMap.put("所属支行", one.get("subBranchName"));
reMap.put("银行卡号", one.get("cardNumber"));
reMap.put("提现金额", one.get("arrivalAmountMoney"));
reMap.put("提现状态", state == -1 ? "处理中" : state == 1 ? "已处理" : state == 0 ? "待处理" : state == 2 ? "信息错误" : "千万不要打款");
reMap.put("支付宝账号", one.get("withdraw"));
reMap.put("提现方式", (Integer) one.get("withdrawType") == 0 ? "支付宝" : "银行卡");
reMap.put("备注", one.get("remark"));
reMap.put("打款进度", "");
rows.add(reMap);
if ((Integer) one.get("withdrawType") == 0) {//支付宝提现
Map<String, Object> ss = reMap;
ss.remove("银行卡户主名称", one.get("userName"));
ss.remove("银行", one.get("bankName"));
ss.remove("银行卡号", one.get("cardNumber"));
ss.remove("所属支行", one.get("subBranchName"));
zifu.add(ss);
}
if ((Integer) one.get("withdrawType") == 1) {//银行卡提现
Map<String, Object> ss = reMap;
ss.remove("支付宝账号", one.get("withdraw"));
yinhang.add(ss);
}
}
List<String> head = new ArrayList<>();
head.add("提现编号");
head.add("用户ID");
head.add("用户名称");
head.add("用户手机号");
head.add("银行卡户主名称");
head.add("银行");
head.add("所属支行");
head.add("银行卡号");
head.add("提现金额");
head.add("提现状态");
head.add("支付宝账号");
head.add("提现方式");
head.add("备注");
head.add("打款进度");
WorkbookUtil workbookUtil = new WorkbookUtil();
HSSFSheet sheet1 = workbookUtil.writeExcel(rows, head, "用户总提现");
sheet1.setColumnWidth(5,30 * 256);
sheet1.setColumnWidth(6,30 * 256);
sheet1.setColumnWidth(7,30 * 256);
List<String> head1= (List<String>) ((ArrayList<String>) head).clone();
head1.remove(10);
HSSFSheet sheet2 = workbookUtil.writeExcel(yinhang, head1, "银行卡提现");
sheet2.setColumnWidth(5,30 * 256);
sheet2.setColumnWidth(6,30 * 256);
sheet2.setColumnWidth(7,30 * 256);
List<String> head2=(List<String>) ((ArrayList<String>) head).clone();
head2.remove(4);
head2.remove(4);
head2.remove(4);
head2.remove(4);
HSSFSheet sheet3 = workbookUtil.writeExcel(zifu, head2, "支付宝提现");
// 第六步,将文件存到指定位置
ServletOutputStream out = response.getOutputStream();
try {
response.setContentType("application/vnd.ms-excel;charset=ISO8859-1");
response.setHeader("Content-Disposition", "attachment;filename=" + new String("用户提现".getBytes("UTF-8"), "ISO8859-1") + new SimpleDateFormat("yyyy-MM-dd->HH").format(new Date()) + ".xls");
workbookUtil.getWorkbook().write(out);
} catch (Exception e) {
e.printStackTrace();
} finally {
out.close();
}
return;
使用的方法片段。记录一下
一篇在一个Excel表中创建多个sheet的代码的更多相关文章
- C#利用NPOI在同一个Excel文件中创建多个sheet
借用NPOI来实现,要在同一Excel文件中创建多个sheet,只需要在同一个workbook中创建多个sheet即可.要注意的是,sheet的名字一定不能重复.下面是实现的代码: private v ...
- 【PHP】将EXCEL表中的数据轻松导入Mysql数据表
在网络上有不较多的方法,在此介绍我已经验证的方法. 方法一.利用EXCEL表本身的功能生成SQL代码 ①.先在“phpmyadmin”中建立数据库与表(数据库:excel,数据表:excel01,字段 ...
- 获取Excel表中各个Sheet的方法
获取Excel表中各个Sheet的方法 private void simpleButton2_Click(object sender, EventArgs e) { OfdBOM.Filter = & ...
- 此文本文件包含的数据无法放置在一个工作表中 gb2312
excel导入csv,csv要从unicode转为gb2312, 否则提示:此文本文件包含的数据无法放置在一个工作表中
- 将从数据库中获取的数据写入到Excel表中
pom.xml文件写入代码,maven自动加载poi-3.1-beta2.jar <!-- https://mvnrepository.com/artifact/poi/poi --> & ...
- 将EXCEL表中的数据轻松导入Mysql数据表
转载自:http://blog.163.com/dielianjun@126/blog/static/164250113201042310181431/ 在网络上有不较多的方法,在此介绍我已经验证的方 ...
- 将Excel表中的数据导入MySQL数据库
原文地址: http://fanjiajia.cn/2018/09/26/%E5%B0%86Excel%E8%A1%A8%E4%B8%AD%E7%9A%84%E6%95%B0%E6%8D%AE%E5% ...
- 【数据传输 2】批量导入的前奏:将Excel表中的数据转换为DataTable类型
导读:我们知道,在数据库中,数据集DataSet是由多张DataTable表组成.所以,如果我们需要将数据从外部导入到数据库中,那么要做的很重要的一步是将这些数据转换为数据库可以接受的结构.今天在用S ...
- 复制excel表,往excel表中写入数据
import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.IOException;import jav ...
随机推荐
- monkeyrunner小结
上次说到已经配好了MonkeyRunner的运行环境,现在讲解怎么进行简单的MonkeyRunner测试.这个拖了很久才有时间和心情总结一下.真是计划赶不上变化啊. 就不说废话了.http://dev ...
- yii2项目实战-路由美化以及如何正确的生成链接
yii2项目实战-路由美化以及如何正确的生成链接 更新于 2016年12月17日 by 白狼 被浏览了 705 次 美化路由 何为美化路由呢?美化嘛,无外乎就是给路由化化妆,让她好看点.我虽没化过妆, ...
- git reset --soft --hard 区别
[转]git reset 之 soft mixed hard选项的区别 (2014-09-09 16:54:06) 转载▼ 标签: git 分类: Linux 译注:为了避免丢失本地的修改以及orig ...
- vSphere5.5体系结构
1.vSphere5.5体系结构 vSphere5.5作为云集算操作系统,可以虚拟化服务器.存储.网络在内的整个IT基础架构,将这些架构转化为易于管理的虚拟化!vSphere5.5从逻辑上,可以划分为 ...
- jmeter - 命令行方式运行
命令格式: jmeter -n -t <testplan filename> -l <listener filename> 参数说明: -n 非 GUI 模式 -> 在非 ...
- C++ 的写好库编译好,DELPHI或者Java做界面,iOS 和 Android 就都搞定。
当然也可以使用BCB和相关的开发库来开发App,只是别人没法帮助你. 摘自<想到做到-Android开发关键技术与精彩案例>.(詹建飞) p40
- C++友元(友元函数、友元类和友元成员函数)
友元(友元函数.友元类和友元成员函数) C++ 有些情况下,允许特定的非成员函数访问一个类的私有成员,同时仍阻止一般的访问,这是很方便做到的.例如被重载的操作符,如输入或输出操作符,经常需要访问类的私 ...
- jQuery为DOM动态追加事件
处理一个列表绑定,因为是一个展示项目,没有使用复杂的插件,直接jsrender写了个模板,但是后面有一个操作按钮,去查看数据详情,想到了jquery使用on进行事件委托,然后就开搞 最初是这样写的: ...
- [Perl]通过GD模块获取字符/汉字的点阵
原来Perl获取汉字的点阵如此简单 示例脚本应保存为utf8格式 Code: [全选] [展开/收缩] [Download] (Untitled.pl) use GD; use utf8; my $g ...
- pageadmin自助建站 网站目录权限的设置方法
在用pageadmin网页设计的时候遇到各种问题可以参考官网教程网站目录权限的设置方法 网站目录必须设置读取和写入权限,否则后台解压,删除文件,在线上传等功能都无法正常使用,下面讲解本机和服务器配置目 ...