jxl 导出数据到excel
优点:
- Jxl对中文支持非常好,操作简单,方法看名知意。
- Jxl是纯javaAPI,在跨平台上表现的非常完美,代码可以再windows或者Linux上运行而无需重新编写
- 支持Excel 95-2000的所有版本(网上说目前可以支持Excel2007了,还没有尝试过)
- 生成Excel 2000标准格式
- 支持字体、数字、日期操作
- 能够修饰单元格属性
- 支持图像和图表,但是这套API对图形和图表的支持很有限,而且仅仅识别PNG格式。
缺点:
效率低,图片支持不完善,对格式的支持不如POI强大
案例:
String times = (new SimpleDateFormat("yyyyMMddHHmmss")).format(new Date());
String fname = "系统日志" + times; // 文件名
List<Logs> list=logsService.selectForList(hql.toString());
String path = request.getSession().getServletContext().getRealPath("/")
+ "xls/"
+ (new SimpleDateFormat("yyyyMMdd")).format(new Date());
File file = new File(path);
// 如果文件夹不存在则创建
if (!file.exists() && !file.isDirectory()) {
file.mkdir();
}
response.setContentType("application/vnd.ms-excel;charset=utf-8");// // 指定文件的保存类型。
response.setCharacterEncoding("utf-8");
ExportUtil.writer_log(request,fname, list, response);//下载到本地
writer_log导出方法如下
/**
* 生成 excel 文件,导出到本地电脑
* @param fname 文件名
* @param list 需要打印的数据,即数据库查询的数据列表
*/
public static void writer_log(HttpServletRequest request,String fname, List list, HttpServletResponse response) {
try {
OutputStream os = response.getOutputStream();//取得输出流
response.reset();//清空输出流
// 下面是对中文文件名的处理 开始
response.setCharacterEncoding("UTF-8");//设置相应内容的编码格式
if(isMsBrowser(request))
fname= java.net.URLEncoder.encode(fname ,"UTF-8");
else fname = new String(fname.getBytes("UTF-8"),"ISO-8859-1");
response.setHeader("Content-Disposition","attachment;filename="+fname+".xls");
response.setContentType("application/msexcel;charset=utf-8");//定义输出类型
// 对中文文件名的处理 结束 // 此处的 Workbook 导入的是 import jxl.Workbook;
WritableWorkbook wbook = Workbook.createWorkbook(os); // 建立excel文件
WritableSheet sheet = wbook.createSheet("系统日志", 0); // 工作表名称 CellView cellView = new CellView();
cellView.setAutosize(true); //设置自动大小
sheet.setColumnView(0, 8); //设置单元格宽度,0是列号,8是宽度
sheet.setColumnView(1, 20); //设置单元格宽度,1是列号,20是宽度
sheet.setColumnView(2, 24);
sheet.setColumnView(3, 20);
sheet.setColumnView(4, 30);
sheet.setColumnView(5, 13);
sheet.setColumnView(6, 15);
sheet.setColumnView(7, 32);
sheet.setColumnView(8, 15); // 设置Excel字体
WritableFont wfont = new WritableFont(WritableFont.createFont("宋体"), 22,
WritableFont.BOLD, false,
jxl.format.UnderlineStyle.NO_UNDERLINE,
jxl.format.Colour.BLACK); //设置单元格字体样式
WritableCellFormat titleFormat = new WritableCellFormat(wfont); //添加单元格字体
titleFormat.setAlignment(Alignment.CENTRE); //设置文字居中对齐方式;
String[] title = { "系统日志" };
// 设置Excel表头 开始
for (int i = 0; i < title.length; i++) {
// 此处导入的是 import jxl.write.Label;
Label excelTitle = new Label(i, 0, title[i], titleFormat); //单元格内容
// 参数顺序:开始列,开始行,结束列,结束行
sheet.mergeCells(0, 0, 8, 0); //所在位置,第几行第几列
sheet.addCell(excelTitle); //添加单元格信息
}
// 设置Excel表头 结束
// 第一行,即显示时间,参数:(所在列,所在行,内容)
WritableFont wfonttime = new WritableFont(WritableFont.createFont("宋体"), 11,
WritableFont.NO_BOLD, false,
jxl.format.UnderlineStyle.NO_UNDERLINE,
jxl.format.Colour.BLACK); //设置单元格字体样式
WritableCellFormat titletime = new WritableCellFormat(wfonttime);//添加单元格字体
titletime.setAlignment(Alignment.RIGHT); //设置文字居中对齐方式;
DateFormat df = new SimpleDateFormat("yyyy-MM-dd");
// sheet.setColumnView(1, cellView); //根据内容自动设置列宽
Label contentDate = new Label(0, 1, df.format(new Date()), titletime); //单元格内容
// sheet.mergeCells(16, 1, 18, 1); //所在位置,第几行第几列,即合并的位置,如没合并,可不写
sheet.addCell(contentDate); //添加单元格信息
// 第一行 结束
// 第二行,显示条件标题栏
WritableFont wfont2 = new WritableFont(WritableFont.createFont("宋体"), 11,
WritableFont.BOLD, false,
jxl.format.UnderlineStyle.NO_UNDERLINE,
jxl.format.Colour.BLACK); //设置单元格字体样式
WritableCellFormat titleFormat2 = new WritableCellFormat(wfont2);//添加单元格字体
titleFormat2.setBorder(Border.ALL, BorderLineStyle.THIN); //设置边框--实线;
titleFormat2.setAlignment(Alignment.CENTRE); //设置文字居中对齐方式;
titleFormat2.setVerticalAlignment(VerticalAlignment.CENTRE); //设置垂直居中;
Label content2a = new Label(0, 2, "序号", titleFormat2); //单元格内容--第1格
Label content2b = new Label(1, 2, "用户名", titleFormat2); //单元格内容--第2格
Label content2c = new Label(2, 2, "记录时间", titleFormat2); //单元格内容--第3格
Label content2d = new Label(3, 2, "操作模块", titleFormat2); //单元格内容--第4格
Label content2e = new Label(4, 2, "操作内容", titleFormat2); //单元格内容--第5格
Label content2f = new Label(5, 2, "操作动作", titleFormat2); //单元格内容--第6格
Label content2g = new Label(6, 2, "操作人IP", titleFormat2); //单元格内容--第7格
Label content2h = new Label(7, 2, "所属组织", titleFormat2); //单元格内容--第8格
Label content2i = new Label(8, 2, "备注", titleFormat2); //单元格内容--第9格
sheet.mergeCells(0, 1, 8, 1);
/*sheet.mergeCells(0, 2, 0, 4); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到5行,第1列)
sheet.mergeCells(1, 2, 1, 4); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到5行,第2列)
sheet.mergeCells(2, 2, 2, 4); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到5行,第3列)
sheet.mergeCells(3, 2, 3, 4); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到5行,第4列)
sheet.mergeCells(4, 2, 4, 4); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到5行,第5列)
sheet.mergeCells(5, 2, 5, 4); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到5行,第6列)
sheet.mergeCells(6, 2, 6, 4); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到5行,第7列)
sheet.mergeCells(7, 2, 7, 4); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到5行,第8列)
sheet.mergeCells(8, 2, 8, 4); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到5行,第9列)
sheet.mergeCells(9, 2, 9, 4); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到5行,第10列)
sheet.mergeCells(10, 2, 12, 3); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到4行,第11-13列)
sheet.mergeCells(13, 2, 15, 3); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到4行,第14-16列)
sheet.mergeCells(16, 2, 16, 4); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到5行,第17列)
sheet.mergeCells(17, 2, 17, 4); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到5行,第18列)
sheet.mergeCells(18, 2, 18, 4); //所在位置,第几行第几列,即合并的位置,如没合并,可不写;(此处为第3行开始到5行,第19列)
*/ sheet.addCell(content2a); //添加第1格单元格信息
sheet.addCell(content2b); //添加第2格单元格信息
sheet.addCell(content2c); //添加第3格单元格信息
sheet.addCell(content2d); //添加第4格单元格信息
sheet.addCell(content2e); //添加第5格单元格信息
sheet.addCell(content2f); //添加第6格单元格信息
sheet.addCell(content2g); //添加第7格单元格信息
sheet.addCell(content2h); //添加第8格单元格信息
sheet.addCell(content2i); //添加第9格单元格信息
WritableFont wf = new WritableFont(WritableFont.createFont("宋体"), 11,
WritableFont.NO_BOLD, false,
jxl.format.UnderlineStyle.NO_UNDERLINE,
jxl.format.Colour.BLACK); //设置单元格字体样式
WritableCellFormat wcf = new WritableCellFormat(wf); //添加单元格字体
wcf.setBorder(Border.ALL, BorderLineStyle.THIN); //设置边框--实线;
wcf.setVerticalAlignment(VerticalAlignment.CENTRE); //设置垂直对齐
wcf.setAlignment(Alignment.CENTRE); //设置文字水平居中对齐方式;
wcf.setWrap(true); //自动换行 WritableFont wf1 = new WritableFont(WritableFont.createFont("宋体"), 11,
WritableFont.NO_BOLD, false,
jxl.format.UnderlineStyle.NO_UNDERLINE,
jxl.format.Colour.BLACK); //设置单元格字体样式
WritableCellFormat wcf1 = new WritableCellFormat(wf1); //添加单元格字体
wcf1.setBorder(Border.LEFT, BorderLineStyle.THIN); //设置边框--实线;
wcf1.setVerticalAlignment(VerticalAlignment.CENTRE); //设置垂直对齐
wcf1.setAlignment(Alignment.CENTRE); //设置文字水平居中对齐方式; // 以下循环数据库获取的信息
int c = 1; // 用于循环时Excel的行号
Iterator it = list.iterator();
while (it.hasNext()) {
Logs tc = (Logs) it.next();
DateFormat dfmt = new SimpleDateFormat("yyyy.MM"); String xh = String.valueOf(c);
if(xh== null){
xh = "";
}
Label content0 = new Label(0, c+2, xh, wcf); //序号 String name = tc.getUserName();
if(name == null){
name = "";
}
Label content1 = new Label(1, c+2, name, wcf); //用户名 String xrPresent = tc.getLogTime();
if(xrPresent == null){
xrPresent = "";
}
Label content2 = new Label(2, c+2, xrPresent, wcf); //记录时间 String czModel = tc.getModel();
if(czModel == null){
czModel = "";
}
Label content3 = new Label(3, c+2, czModel, wcf); //操作模块 String sex = tc.getContent();
if(sex == null){
sex = "";
}
Label content4 = new Label(4, c+2, sex, wcf); //操作内容 String birthday = tc.getOperate();
if(birthday == null){
birthday = "";
}
Label content5 = new Label(5, c+2, birthday, wcf); //操作动作 String nation = tc.getIp();
if(nation == null){
nation = "";
}
Label content6 = new Label(6, c+2, nation, wcf); //操作人IP String origin = tc.getOrgName();
if(origin == null){
origin = "";
}
Label content7 = new Label(7, c+2, origin, wcf); //所属组织 String bPlace = tc.getRemark();
if(bPlace == null){
bPlace = "";
}
Label content8 = new Label(8, c+2, bPlace, wcf); //备注 String abc="";
Label content9 = new Label(9, c+2, abc, wcf1); //备注 sheet.setRowView(c+2, 600); // 设置行高
sheet.setRowView(c+2, 600);
sheet.setRowView(c+2, 600);
sheet.setRowView(c+2, 600);
sheet.setRowView(c+2, 600);
sheet.setRowView(c+2, 600);
sheet.setRowView(c+2, 600);
sheet.setRowView(c+2, 600);
sheet.setRowView(c+2, 600);
sheet.setRowView(c+2, 600);
sheet.mergeCells(0, c+2, 0, c+2); // 合并第一列第c+2行到第一列第c+2行的所有单元格
sheet.mergeCells(1, c+2, 0, c+2); //mergeCells(a,b,c,d) 单元格合并函数
sheet.mergeCells(2, c+2, 0, c+2); //a 单元格的列号
sheet.mergeCells(3, c+2, 0, c+2); //b 单元格的行号
sheet.mergeCells(4, c+2, 0, c+2); //c 从单元格[a,b]起,向下合并到c列
sheet.mergeCells(5, c+2, 0, c+2); //d 从单元格[a,b]起,向下合并到d行
sheet.mergeCells(6, c+2, 0, c+2);
sheet.mergeCells(7, c+2, 0, c+2);
sheet.mergeCells(8, c+2, 0, c+2);
sheet.mergeCells(9, c+2, 0, c+2);
sheet.addCell(content0);
sheet.addCell(content1);
sheet.addCell(content2);
sheet.addCell(content3);
sheet.addCell(content4);
sheet.addCell(content5);
sheet.addCell(content6);
sheet.addCell(content7);
sheet.addCell(content8);
sheet.addCell(content9);
c++;
}
wbook.write(); // 写入文件
wbook.close();
os.close();
} catch (Exception e) {
throw new PaikeException("导出文件出错");
} }
jxl 导出数据到excel的更多相关文章
- 分别使用POI和JXL导出数据到Excel
1.使用POI 引入jar包 <!-- poi HSSF is our port of the Microsoft Excel 97(-2007) file format (BIFF8) to ...
- 用jxl导出数据到excel
需要jxl.jar 测试结果没问题,代码: package com; import java.io.File; import java.io.IOException; import java.util ...
- JXL 读取 Excel java中jxl导出数据到excel的例子 上传文件
2010-10-14 19:17:06 com.opensymphony.xwork2.util.logging.commons.CommonsLogger info 信息: Entferne Dat ...
- Java操作Jxl实现导出数据生成Excel表格数据文件
实现:前台用的框架是Easyui+Bootstrap结合使用,需要引入相应的Js.Css文件.页面:Jsp.拦截请求:Servlet.逻辑处理:ClassBean.数据库:SQLserver. 注意: ...
- 1.ASP.NET MVC使用EPPlus,导出数据到Excel中
好久没写博客了,今天特地来更新一下,今天我们要学习的是如何导出数据到Excel文件中,这里我使用的是免费开源的Epplus组件. 源代码下载:https://github.com/caofangshe ...
- 导出数据到Excel --使用ExcelReport有感
先看图,这是几个月前用NPOI写的导出数据到Excel,用了上百行代码,而且难控制,导出来也比较难看 excel打开的效果 下面是我用ExcelReport类库导出到Excel的操作 1.首先引用Ex ...
- 使用Open xml 操作Excel系列之二--从data table导出数据到Excel
由于Excel中提供了透视表PivotTable,许多项目都使用它来作为数据分析报表. 在有些情况下,我们需要在Excel中设计好模板,包括数据源表,透视表等, 当数据导入到数据源表时,自动更新透视表 ...
- Dynamics CRM导出数据到Excel
原创地址:http://www.cnblogs.com/jfzhu/p/4276212.html 转载请注明出处 Pivot Table是微软BI的一个重要工具,所以这里讲一下Dynamics CRM ...
- MVC导出数据到EXCEL新方法:将视图或分部视图转换为HTML后再直接返回FileResult
导出EXCEL方法总结 MVC导出数据到EXCEL的方法有很多种,常见的是: 1.采用EXCEL COM组件来动态生成XLS文件并保存到服务器上,然后转到该文件存放路径即可: 优点:可设置丰富的EXC ...
随机推荐
- 在Windows下为PHP5.5安装redis扩展
使用phpinfo()函数查看PHP的版本信息,这会决定扩展文件版本 根据PHP版本号,编译器版本号和CPU架构, 选择php_redis-2.2.5-5.5-ts-vc11-x86.zip和ph ...
- Docker Centos6 下建立 Docker 桥接网络
cd /etc/sysconfig/network-scripts/; cp ifcfg-eth0 ifcfg-br0 vi ifcfg-eth0 //增加BRIDGE=br0,删除IPADDR,N ...
- Scrapy-简单介绍
Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 可以应用在包括数据挖掘,信息处理或存储历史数据等一系列的程序中. 其最初是为了 页面抓取 (更确切来说, 网络抓取 )所设计的, ...
- 关于ruby -gem无法切换淘宝源
ruby官网提供的 淘宝的gem源 不起作用 https://ruby.taobao.org/ taobao Gems 源已停止维护,现由 ruby-china 提供镜像服务 http://gems. ...
- iOS实现微信外部H5支付完成后返回原APP
看到微信最近放开了微信H5支付,公司决定把H5集成到多款APP上.下面记录下了开发过程. 由于是微信新推出的支付方式,在网上搜索到的相关资料并不多,其中有一篇文件(点此跳转)对我的整个开发过程起到了很 ...
- linux磁盘及分区详解
1.Linux 分区简介 1.1 主分区 vs 扩展分区 硬盘分区表中最多能存储四个分区,但我们实际使用时一般只分为两个分区,一个是主分区(Primary Partion)一个是扩展分区(extend ...
- Android查缺补漏(IPC篇)-- Bundle、文件共享、ContentProvider、Messenger四种进程间通讯介绍
本文作者:CodingBlock 文章链接:http://www.cnblogs.com/codingblock/p/8387752.html 进程间通讯篇系列文章目录: Android查缺补漏(IP ...
- 树莓派系列教程:1.环境与系统,无显示器无键盘无网线联网并使用PuTTy与VNC图形界面远程登录
本文所需物品清单: Raspberry Pi 3 Model B 主板.SD卡与读卡器(用于烧录系统) 资料整理来源在文尾 需要下载的资源与工具: 推荐系统-Raspbian 树莓派官方深度定制的硬件 ...
- 通过Yii来理解MVC
模型:是表现业务数据.规则和逻辑的对象. 可以通过集成yii\base\Model或者它的子类定义模型类. 基类yii\base\Model支持许多实用的特性: A 属性:表现业务数据,可以像普通类属 ...
- UVA-714 二分
把可能的进行二分判断,判断的时候尽量向右取,一直取到不能去为止,这样才有可能成功分割. 判断是否可以把up作为最大值的代码: bool judge(LL up){ if(up < Big) re ...