【java】:生成excel
//生成报表公用方法
//excelName: 生成的文件名
//list:时间/日期/描述
//listSelectFiled: 标题
//showContent : 文件内容bean
//生成报表公用方法
public String createExcelFile(String excelName,List<String[]> listSelectField,String[] fields,List<String[]> showContent){
HSSFWorkbook wb = new HSSFWorkbook();
HSSFSheet sheet = wb.createSheet();
HSSFCellStyle setBorder = wb.createCellStyle();
//设置背景颜色
//setBorder.setFillBackgroundColor((short)13);
//setBorder.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
//设置边框
setBorder.setBorderBottom(HSSFCellStyle.BORDER_THIN);
setBorder.setBorderLeft(HSSFCellStyle.BORDER_THIN);
setBorder.setBorderTop(HSSFCellStyle.BORDER_THIN);
setBorder.setBorderRight(HSSFCellStyle.BORDER_THIN);
//设置居中
setBorder.setAlignment(HSSFCellStyle.ALIGN_CENTER);//居中
//设置字体
HSSFFont font = wb.createFont();
font.setFontName("黑体");
font.setFontHeightInPoints((short)16);//设置字体大小
HSSFFont font3 = wb.createFont();
font3.setFontName("宋体");
//font2.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);//粗体显示
font3.setFontHeightInPoints((short)14);//设置字体大小
HSSFFont font2 = wb.createFont();
font2.setFontName("宋体");
//font2.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);//粗体显示
font2.setFontHeightInPoints((short)12);//设置字体大小
setBorder.setFont(font); //选择需要的字体
//设置列宽
for (int i = 0; i < fields.length; i++) {
sheet.setColumnWidth((short)i, (short)4000);
}
//所有内容居中显示的 样式(内容部分)
HSSFCellStyle cellstyle = wb.createCellStyle();
cellstyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);//居中
cellstyle.setFont(font2);
HSSFCellStyle selestyle = wb.createCellStyle();
selestyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);//居中
selestyle.setFont(font2);
//合并单元格
Region region = new Region(0,(short)0,0,(short)14);
sheet.addMergedRegion(region);
//第一行标题
HSSFRow row1 = sheet.createRow(0);
row1.setHeight((short)500);
HSSFCell celltitle = row1.createCell((short)0);
celltitle.setCellType(HSSFCell.CELL_TYPE_STRING);
celltitle.setCellValue(excelName);
celltitle.setCellStyle(setBorder);
//合并单元格
int ce = 0;
for (int i = 0; i < listSelectField.size(); i++) {
sheet.addMergedRegion(new Region(1,(short)ce,1,(short)(++ce)));
ce+=2;
}
//第二行查询条件
ce=0;
HSSFRow row2 = sheet.createRow(1);
row2.setHeight((short)300);
for (int i = 0; i < listSelectField.size(); i++) {
HSSFCell selectfields1 = row2.createCell((short)ce);
selectfields1.setCellType(HSSFCell.CELL_TYPE_STRING);
selectfields1.setCellValue(listSelectField.get(i)[0]+":"+listSelectField.get(i)[1]);
selectfields1.setCellStyle(cellstyle);
ce+=3;
}
//需要显示的字段名称
HSSFRow row3 = sheet.createRow(2);
int index= 0;
for(String str : fields){
HSSFCell cell = row3.createCell((short)index);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue(str);
cell.setCellStyle(cellstyle);
index++;
}
//需要显示的内容
for (int i = 0; i < showContent.size(); i++) {
HSSFRow row = sheet.createRow(i+3);
String[] content = showContent.get(i);
for(int j = 0;j<content.length;j++){
HSSFCell cell = row.createCell((short)j);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue(content[j]);
cell.setCellStyle(cellstyle);
}
}
String destFileName = StringUtil.getNowDateFormat(null);
String fileName = excelName+"("+destFileName+").xls";
System.out.println("<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<"+fileName);
try {
String saveurl = PathManager.getWEBINFPath()+java.io.File.separator+".."+java.io.File.separator+"ucstar_plugins"+java.io.File.separator+"ucstarwebcall"+java.io.File.separator+"reportfile"+java.io.File.separator+"";
File fileurl = new File(saveurl);
if(!fileurl.exists()){
fileurl.mkdirs();
}
File f = new File(saveurl+java.io.File.separator+fileName);
System.out.println("<<<<<<<<<<<<<<<<<<<<<<<<<<<<"+saveurl+java.io.File.separator+fileName);
f.createNewFile();
FileOutputStream fos = new FileOutputStream(f);
wb.write(fos);
fos.close();
Log.console(">>>>>>>生成Excel成功!");
} catch (Exception e) {
Log.console(">>>>>>>生成Excel失败:"+e.getMessage());
return "";
}
return fileName;
}
}
【java】:生成excel的更多相关文章
- java 生成Excel开门篇
本随笔的Excel所用的poi jar包(3.17版本)链接: https://pan.baidu.com/s/1gaa3dJueja8IraUDYCSLIQ 提取密码: 9xr7 简单实现:两个类: ...
- oracle PL/SQL调用Java生成Excel
现在有个需求, 要求编写oracle存储过程生成Excel文件到指定目录, 但是oracle自己的API貌似不太给力, 所以只能通过另一种更强大的语言来实现了 ——Java.有一个Java框架 ...
- JAVA生成EXCEL模板
JAVA生成excel模板,支持1.必填字段前加 红色 * 2.定义可选值下拉列表 valList3.定义名称并通过名称设置可选值 refName(名称在sheet2,sheet2自动隐藏)4.支持设 ...
- 两种方式实现java生成Excel
Web应用中难免会遇到需要将数据导出并生成excel文件的需求.同样,对于本博客中的总结,也是建立在为了完成这样的一个需求,才开始去了解其实现形式,并且顺利完成需求的开发,先将实现过程总结于此.本博文 ...
- Java生成excel导出文件(使用poi+JXL)
1.使用poi生成文件 package com.mi.entity; import java.util.Date; public class Student { private int id; pri ...
- [转]java生成 excel 并导出文件
原文:https://blog.csdn.net/xunwei0303/article/details/53213130 目前,比较常用的实现Java导入.导出Excel的技术有两种Jakarta P ...
- java生成excel报表文件
此次简单的操作将数据从数据库导出生成excel报表以及将excel数据导入数据库 首先建立数据库的连接池: package jdbc; import java.io.FileInputStream; ...
- java生成excel,word文件
第一部分: 在网站开发中,用户可能需要打印word或者excel表,这种需求是非常多的. java语言生成excel表格和python的方式有点像,使用Apache POI的组件,一通全通.开发过程通 ...
- JAVA生成EXCEL图表
跟据客户的要求,需要开发一套包括图形的报表,还需要导出WORD 图表需要这样: 这样: 这样: 还有这样: 接下来是实现思路: 以往用的最多的就是JFreechart,手上也有实现各种图形的资源,但是 ...
- java生成excel
package test.poi; import java.io.File; import java.io.FileOutputStream; import java.io.OutputStream; ...
随机推荐
- boost::asio::socket tcp 连接 在程序结束时崩溃。
刚开始的时候一直不知道怎么回事,不过幸好我有在每个class 的析构时都打印一条信息. 这个时候发现我的一个tcp_connection (就是自定义的一个连接类) 在最后才被析构. 所以感觉这里可能 ...
- go1.6.2 linux/amd64 的一个bug: gcc: 无法识别的选项‘-no-pie’
如果你的linux是中文版的. 即:执行 # echo $LANG 命令,返回的是 zh_CN.UTF-8 则会出现这个bug, 如果是 en_US.UTF-8 则没有这个问题. 这个bug的一个 ...
- (DP)3.Longest Substring Without Repeating Characters
Given a string, find the length of the longest substring without repeating characters. For example, ...
- day01-02--数据库概念介绍
什么是数据库呢?是存放数据的仓库.这个仓库比较特殊--它是按照一定的数据结构来组织.存储的.当然,我们也需要管理仓库中的货物--我们通过数据库提供的多种方法来管理数据库里的数据. 来自为知笔记(Wiz ...
- Symfony2 资料篇
http://www.chrisyue.com/symfony2-in-action-day-1.html 由于Symfony2现在还没有很完善的中文文档,所以不想看文档的同学可以直接进行点击上面的链 ...
- 【转载】JMeter学习(一)工具简单介绍
JMeter学习(一)工具简单介绍 一.JMeter 介绍 Apache JMeter是100%纯JAVA桌面应用程序,被设计为用于测试客户端/服务端结构的软件(例如web应用程序).它可以用来测试静 ...
- mac 使用技巧 (实时更新)
一.部分快捷键. 这个在网上有一大堆,不过笔者认为,还是应该看个人习惯和使用环境吧.如果用得顺手,那就是快捷键,如果用得不顺手,那应该称其为“辅助键”吧. 下面介绍几个常用的快捷键: 1.截图. 屏幕 ...
- Python list 操作
创建列表sample_list = ['a',1,('a','b')] Python 列表操作sample_list = ['a','b',0,1,3] 得到列表中的某一个值value_start = ...
- java文件保存至服务器
import java.io.ByteArrayOutputStream;import java.io.File;import java.io.FileOutputStream;import java ...
- C++学习基础九——继承
1.不同于Java中通过extends实现继承,C++是通过:实现的. 2.C++中同样包含public,private,protected三个关键字: public关键字表示在任意其他类中可调用该成 ...