Java写Excel(不生成实体文件,写为流的形式)
java 写 Excel(不生成实体文件,写为流的形式)
public String exportReportExcel(String mediaCode, List<SimpleMediaResourceInfo> mediaResourceInfos) {
String scheduleURL = "";
// 1. 根据不同的媒介code查询对应的媒介细节内容
List<MediaContent> mediaContents = mediaContentMapper.selectByMediaCode(mediaCode);
// 2. 组装header
List<String> medias = new ArrayList<String>();
for (MediaContent mediaContent : mediaContents) {
medias.add(mediaContent.getAttrName());
}
String[] headers = new String[medias.size()];
headers = medias.toArray(headers);
// 3. 将内容写入对应的Excel
try {
ByteArrayOutputStream os = new ByteArrayOutputStream();
Workbook workbook = new XSSFWorkbook();
// 生成一个表格
Sheet sheet = workbook.createSheet();
sheet.setDefaultColumnWidth(13); // 调整列宽度
writeHeader(headers, workbook, sheet);
writeData(mediaResourceInfos, medias, sheet);// 遍历集合数据,产生数据行
workbook.write(os);
ByteArrayInputStream is = new ByteArrayInputStream(os.toByteArray());
scheduleURL = JdStorageService.getInstance().upload(is, (int) os.size(), "export.xls");
os.flush();
os.close();
is.close();
} catch (Exception e) {
e.printStackTrace();
}
return scheduleURL;
}
private void writeHeader(String[] headers, Workbook workbook, Sheet sheet) {
CellStyle style = workbook.createCellStyle();
XSSFFont font = (XSSFFont) workbook.createFont();
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);// 粗体显示
style.setFont(font);
style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 水平居中
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 垂直居中
// style.setFillForegroundColor(IndexedColors.TEAL.getIndex());
// //设置背景色
// style.setFillPattern(CellStyle.SOLID_FOREGROUND);
Row row0 = sheet.createRow(0);
row0.setHeightInPoints(18);
Cell showTimeTitle = row0.createCell((short) 0);
showTimeTitle.setCellValue("投放时间段(必填)");
Cell showTime = row0.createCell((short) 1);
showTime.setCellValue(" ");// TODO 时间问题
Cell remark = row0.createCell((short) 2);
remark.setCellValue("整个媒介投放的时间区间,按照从投放第一天到投放最后一天,如中间有间隔,需要用\",\"分开填写");
// 产生表格标题行
Row row = sheet.createRow(1);
row.setHeightInPoints(21);
for (int i = 0; i < headers.length; i++) {
Cell cell = row.createCell((short) i);
RichTextString text = new HSSFRichTextString(headers[i]);
cell.setCellValue(text.toString());
cell.setCellStyle(style);
}
}
private void writeData(List<SimpleMediaResourceInfo> mediaResourceInfos, List<String> medias, Sheet sheet) {
Row row;
if (!CollectionUtils.isEmpty(mediaResourceInfos)) {
int index = 2;
for (SimpleMediaResourceInfo rowData : mediaResourceInfos) {
row = sheet.createRow(index);
row.setHeightInPoints(21);
int cellIndex = 0;
if (!CollectionUtils.isEmpty(rowData.getMediaResourceTypes())
|| !CollectionUtils.isEmpty(rowData.getDetailContents())) {
for (String header : medias) {
for (SimpleMediaResourceType columnInfo : rowData.getMediaResourceTypes()) {
if (header.equals(columnInfo.getAttrName())) {
Cell cell = row.createCell((short) cellIndex);
cell.setCellValue(columnInfo.getAttrValue().toString());
}
}
for (SimpleMediaDetailContentItem columnInfo : rowData.getDetailContents()) {
if (header.equals(columnInfo.getAttrName())) {
Cell cell = row.createCell((short) cellIndex);
cell.setCellValue(columnInfo.getAttrValue().toString());
}
}
if (header.equals("时段")) {
Cell cell = row.createCell((short) cellIndex);
cell.setCellValue(ShowTimeHelper.transferFrom(rowData.getShowTimes()).toString());
}
cellIndex++;
}
index++;
}
}
}
}
Java写Excel(不生成实体文件,写为流的形式)的更多相关文章
- java 写 Excel(不生成实体文件,写为流的形式)
java 写 Excel(不生成实体文件,写为流的形式) public String exportReportExcel(String mediaCode, List<SimpleMediaRe ...
- openpyxl -用于读/写Excel 2010 XLSX/XLSM文件的python库
openpyxl -用于读/写Excel 2010 XLSX/XLSM文件的python库¶ https://www.osgeo.cn/openpyxl/index.html
- JAVA中使用freemark生成自定义文件(json、excel、yaml、txt)
原文:http://blog.csdn.net/jinzhencs/article/details/51461776 场景:在我们工作中,有时需要生成一些文件,可能它不是一种标准的格式,比如JSON. ...
- Python:Dom生成XML文件(写XML)
http://www.ourunix.org/post/327.html 在python中解析XML文件也有Dom和Sax两种方式,这里先介绍如何是使用Dom解析XML,这一篇文章是Dom生成XML文 ...
- 如何使用Java创建Excel(.xls 和 .xlsx)文件 并写入数据
1,需要依赖的jar包, <!-- POI(operate excel) start --> <!-- the version of the following POI packag ...
- Java根据Freemarker模板生成Word文件
1. 准备模板 模板 + 数据 = 模型 1.将准备好的Word模板文件另存为.xml文件(PS:建议使用WPS来创建Word文件,不建议用Office) 2.将.xml文件重命名为.ftl文件 3 ...
- Java解析XML与生成XML文件
XML是eXtensible Markup Language(可扩展标记语言)的简写形式,它是一种元标记语言(meta-markup language),也就是说它没有一套能够适用于各个领域中所有用户 ...
- Java KeyStore 用命令生成keystore文件
1.生成keyStore文件 在命令行下执行以下命令: Shell代码 收藏代码 keytool -genkey -validity 36000 -alias www.zlex.org -keyalg ...
- Java KeyStore 用命令生成keystore文件自己生成证书,简介
1.生成keyStore文件 在命令行下执行以下命令: Shell代码 收藏代码 keytool -genkey -validity 36000 -alias www.zlex.org -keyalg ...
随机推荐
- Linux下利用script命令录制并回放终端会话
Linux下利用script命令录制并回放终端会话 核心命令 script 和 scriptreplay 录制屏幕 script -t 2>timescript typescript 命令解释: ...
- 面向对象设计之------Is-A(继承关系)、Has-A(合成关系,组合关系)和Use-A(依赖关系)(转)
原文url:http://blog.csdn.net/loveyou128144/article/details/4749576 @Is-A,Has-A,Use-A则是用来描述类与类之间关系的.简单的 ...
- BIEE入门(二)物理层的定义
使用BIEE的第一步是使用admintool去建立一个多维数据模型,而建立多维数据模型的第一步则是建立物理层,请注意因为BIEE本身并不存 储数据,所以所谓BIEE物理层的意义是需要在BIEE里建立各 ...
- ul自适应li问题
内容提要: li浮动时ul高度为0,解决ul自适应高度的几种方法 在网页设计中,常常需要对li标签做浮动效果,但是在不同浏览器中会遇到兼容性问题,比如IE中会出现ul高度为0的情况,是效果不能达到预期 ...
- 初识Git与Github
学习和使用Git和Github的确是一件很有意义的事,通过使用Git和Github,可以让我们很方便地管理自己的各种文件,还可以帮助一名程序员更好地用于代码管理.而对于一名软件技术人员,建立自己的Gi ...
- Android进阶笔记13:ListView篇之ListView刷新显示(全局 和 局部)
一.ListView内容变化后,动态刷新的步骤(全局刷新): (1)更新适配器Adapter数据源:(不要使用匿名内部类) (2)调用适配器Adapter的刷新方法notifyDataSetChang ...
- Android——Activity生命周期
启动: 触发 onCreate() onStart() onResume() Home键: 触发 onPause() onStop() back键退出: 触发 onPause() o ...
- 课堂笔记——循环语句-for
一.循环:多次执行某段代码. 二.循环四要素: 1.初始条件 2.循环条件 3.状态改变 4.循环体 三.for循环 1.语法: for(初始条件;循环条件;状态改变) { 循环体 } 2 ...
- PHP设计模式——适配器模式
<?php /** * 适配器模式 * 适配器模式是将某个对象的接口适配为另一个对象所期望的接口 * * 在需要转化一个对象的接口用于另一个对象时,最好实现适配器模式对象 */ class We ...
- 运行出现Server Tomcat v8.5 Server at localhost failed to start.和A child container failed during start
出现问题: 解决方法: 1.看servlet文件中的@WebServlet“()”,里面是否少了/字符,如图: 加上即可,有问题随时留言,欢迎您的咨询!