java利用poi导出数据到excel
背景:
上一篇写到利用jtds连接数据库获取对应的数据,本篇写怎样用poi将数据到处到excel中,此程序为Application
正文:
/**
* 将数据导出到excel中
* @param data 将要被导入到excel中的数据
* @throws IOException
*/
public void crateTempFile(ArrayList<LinkedHashMap<String, String>> data) throws IOException {
//建立一个excel工作簿
HSSFWorkbook wb = new HSSFWorkbook();
//建立一个sheet
HSSFSheet sheet = wb.createSheet("test");
//建立一个单元格样式
HSSFCellStyle commonTitileStyle = wb.createCellStyle();
//建立一个字体样式
HSSFFont font=wb.createFont();
//设置字体颜色
font.setColor(HSSFColor.RED.index);//HSSFColor.VIOLET.index //字体颜色
//设置字体的大小
font.setFontHeightInPoints((short)12);
//字体增粗
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
//将字体样式放入单元格样式中
commonTitileStyle.setFont(font);
//建立一行
HSSFRow titleRow = sheet.createRow(0);
Map<String, String> titleMap = data.get(0);
Set<String> keySet = titleMap.keySet();
Iterator<String> it = keySet.iterator();
//sheet中行索引值
int indexOfRow = 0;
//建立第一行第一个单元格
HSSFCell titileCell = titleRow.createCell(indexOfRow);
String titilKey = "測试測试(6072)";
//设置单元格宽度
sheet.setColumnWidth(indexOfRow, 20 * 256);
//给单元格赋值
titileCell.setCellValue(titilKey);
//设置单元格样式
titileCell.setCellStyle(commonTitileStyle);
indexOfRow = 1;
//设置sheet第二行
HSSFRow dataRow = sheet.createRow(indexOfRow);
while (it.hasNext()) {
//遍历建立第二行单元格格式
HSSFCell cell1 = dataRow.createCell(indexOfRow-1);
String key1 = it.next();
//将数据库表中的字段名改为改动成excel中的须要的标题名称
key1 = dbColumnNameToExcelColumnName(key1);
sheet.setColumnWidth(indexOfRow, 20 * 256);
cell1.setCellValue(key1);
indexOfRow++;
}
//设置第三行
indexOfRow = 2;
for (Map<String, String> temp : data) {
HSSFRow titleRow1 = sheet.createRow(indexOfRow);
Set<String> set = temp.keySet();
Iterator<String> it1 = set.iterator();
int indexOfColumn = 0;
while (it1.hasNext()) {
String key = it1.next();
if (key.equals("anchor_name") || key.equals("send_gift_user_name") || key.equals("add_date")) {
String value = temp.get(key);
if (key.equals("add_date")) {
Date d = new Date(Long.valueOf(value));
SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
value = sdf.format(d);
}
HSSFCell cell = titleRow1.createCell(indexOfColumn);
cell.setCellValue(value);
} else {
long value = Long.valueOf(temp.get(key));
HSSFCell cell = titleRow1.createCell(indexOfColumn);
cell.setCellValue(value);
}
indexOfColumn++;
}
indexOfRow++;
}
FileOutputStream fos = new FileOutputStream(new File("D://test//" + new Random().nextInt(100) + ".xls"));
wb.write(fos);
fos.close();
}
体会:
java利用poi导出数据到excel的更多相关文章
- 使用poi导出数据到excel
一.首先是导入poi所需要的jar包,我是用的是maven,添加jar包依赖 <dependency> <groupId>org.apache.poi</groupId& ...
- spring boot 使用POI导出数据到Excel表格
在spring boot 的项目经常碰到将数据导出到Excel表格的需求,而POI技术则对于java操作Excel表格提供了API,POI中对于多种类型的文档都提供了操作的接口,但是其对于Excel表 ...
- springboot2.1.8使用poi导出数据生成excel(.xlsx)文件
前言:在实际开发中经常需要将数据库的数据导出成excel文件,poi方式则是其中一种较为常用的导出框架.简单读取excel文件在之前的一篇有说明 本项目实现需求:user发出一个导出student信息 ...
- 利用OLEDB导出数据到Excel
原帖地址:http://blog.csdn.net/cpp2017/archive/2008/04/02/2245396.aspx 利用OELDB数据访问对象操作Excel文件,达到将数据导出到Exc ...
- JXL 读取 Excel java中jxl导出数据到excel的例子 上传文件
2010-10-14 19:17:06 com.opensymphony.xwork2.util.logging.commons.CommonsLogger info 信息: Entferne Dat ...
- Java利用POI导入导出Excel中的数据
首先谈一下今天发生的一件开心的事,本着一颗android的心我被分配到了PB组,身在曹营心在汉啊!好吧,今天要记录和分享的是Java利用POI导入导出Excel中的数据.下面POI包的下载地 ...
- java操作Excel之POI(4)利用POI实现数据的批量导出
后台导出方法: /** * 后台导出方法 * 利用POI实现数据的批量导出 */ public String export() throws Exception{ Connection con = n ...
- Java使用POI实现数据导出excel报表
Java使用POI实现数据导出excel报表 在上篇文章中,我们简单介绍了java读取word,excel和pdf文档内容 ,但在实际开发中,我们用到最多的是把数据库中数据导出excel报表形式.不仅 ...
- Java导出数据为EXCEL的两种方式JXL和POI
JXL和POI导出数据方式的比较 POI支持excel2003和2007,而jxl只支持excel2003. 下面为测试代码: public class TestCondition { /** * 生 ...
随机推荐
- Html5响应式设计与实现广场
由于提出的想法响应式设计,越来越多的网站使用这样的思想.各类大型网站如雨后春笋般涌了出来.例如:小米商城.天猫等. 至于响应式设计的概念等大家能够去百度百度,我这里就不相信解说了.直接为大家带来源代码 ...
- HDU--3829--Cat VS Dog【最大点独立集】
链接:http://acm.hdu.edu.cn/showproblem.php?pid=3829 题意:动物园有n条狗.m头猫.p个小孩,每一个小孩有一个喜欢的动物和讨厌的动物.如今动物园要转移一些 ...
- 怎么样eclipse发达国家多重聚合关系maven项目和使用git管理
最近使用的项目的开发maven,多于maven有项目之间有一定的联系,因此,创建一个单独的,然后,maven聚合管理. 项目采用git要管理代码.由于上传的代码集时,.gitignore不要上传文件. ...
- hdu1023
import java.math.BigInteger; import java.util.Scanner; public class Main { static BigInteger fac(Big ...
- oracle connect by 说明
Oracle能够通过START WITH . . . CONNECT BY . . .子句来实现SQL分层查询,这递归查询 例如: select level||'月' 月份 from dual con ...
- AngularJS+ASP.NET MVC+SignalR实现消息推送
原文:AngularJS+ASP.NET MVC+SignalR实现消息推送 背景 OA管理系统中,员工提交申请单,消息实时通知到相关人员及时进行审批,审批之后将结果推送给用户. 技术选择 最开始发现 ...
- cocos2d-x教程2:在windows下怎样批量转换pvr,ccz为png或jpg
这是一个非经常见的功能,可是找了全网,竟然找不到,于是借鉴别人的批处理文件,改了下,就能够把整个文件夹的所有一次批量转换. 将这个bat文件暂定为,myConvert.bat,运行时就把这个bat文件 ...
- Chain of Responsibility - 责任链模式
定义 使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合度. 案例 比方如今有一个图形界面,它包含一个应用Application类,一个主窗体Window,一个buttonButton ...
- 安装Team Foundation Server 2012过程截图
原文:安装Team Foundation Server 2012过程截图 专题图 1,下载Team Foundation Server 2012 官方下载: http://www.microsoft ...
- IBM Java架构师的技能
一天,群里飘过一个IBM招聘信息.我看过之后,也只是如此而已. 大家好!我是XXX,IBM招聘java架构师,如今还有38个名额 学历大专以上即可,英语能面试交流的.项目有非常多到时候依据您面试会详谈 ...