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 { /** * 生 ...
随机推荐
- [Oracle] 分析功能(1)- 语法
语法概览 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvZGJhbm90ZQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQ ...
- 如何安装一个优秀的BUG管理平台(转)
前言 就BUG管理而言,国内的禅道做得很不错,而且持续有更新.我们来看看如何从头到尾安装禅道,各位要注意的是,不是文章深或者浅,而是文章如何在遇到问题的时候,从什么途径和用什么方法解决问题的.现在发觉 ...
- [程序安装包制作] Advanced Installer 备忘
原文:[程序安装包制作] Advanced Installer 备忘 Product Information - Product Details 这个重点是Product Version.讲这个之前, ...
- Objective-C基调(4)Category
OC它提供了一种不同的方式--Category,可以动态地添加新的行为已经存在的类(方法),这确保了较小的类的原始设计,然后逐渐加入扩展. 正在使用Category扩张的上课时间,你并不需要创建一个子 ...
- Delphi 3D Glscene安装
GLScene开源库Delphi基于提供OpenGL的3D框架.由GLScene组件,您可以轻松地创建和渲染你的3D幕后.令人奇怪的是,.对于这样一个很好的开源库.该网络无法找到完整的安装说明,甚至G ...
- 关于接收POST请求 $GLOBALS['HTTP_RAW_POST_DATA']
总是产生变量包含有原始的 POST 数据.否则,此变量仅在碰到未识别 MIME 类型的数据时产生.不过,访问原始 POST 数据的更好方法是 php://input.$HTTP_RAW_POST_DA ...
- 记得12306货运系统“抢购空”编写插件--chrome交互式插件的各个部分
--chrome交互式插件的各个部分 Chrome插件的基础知识就不多说了.随便找个新手教程就能够上手了,比如官方提供的Overview与Getting Started教程足够入门了:笔者也是现学现卖 ...
- [ACM] hdu 1285 确定比赛 (拓扑排序)
确定比赛 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- JS中call、apply的用法说明
JS Call()与Apply()的区别 ECMAScript规范给所有函数都定义了Call()与apply()两个方法,call与apply的第一个参数都是需要调用的函数对象,在函数体内这个参数就是 ...
- 经典算法题每日演练——第六题 协同推荐SlopeOne 算法
原文:经典算法题每日演练--第六题 协同推荐SlopeOne 算法 相信大家对如下的Category都很熟悉,很多网站都有类似如下的功能,“商品推荐”,"猜你喜欢“,在实体店中我们有导购来为 ...