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 { /** * 生 ...
随机推荐
- ACM-DP最大连续子——hdu1231
***************************************转载请注明出处:http://blog.csdn.net/lttree************************** ...
- Cocos2d-X中间应用
(层)Laye:与球员打交道响应事件Node子类. 不同的场景,层通常包括直接在屏幕上呈现的内容.而且能够接受用户的输入事件.包括触摸,加速度计和键盘输入等. 我们须要在层中加入精灵,文本标签或者其它 ...
- Team Foundation Server 2015使用教程--新增权限为读取器的团队
- Docker简介(转)
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相互之间不会有任何 ...
- 每天一点点java---继承exception类来实现自己的异常类
package prac_1; /** * <p>Title: 捕获异常和实现自己的异常类</p> * <p>Description: 通过继承Exception类 ...
- [SignalR]异常信息捕获以及处理
原文:[SignalR]异常信息捕获以及处理 异常处理,一般采用try..catch方式处理,而signalR里面有HubPipelineModule类可以捕获到Hub内发生的异常信息. 从上图中,可 ...
- 《Java并发编程实战》第二章 线程安全 札记
一个.什么是线程安全 编写线程安全的代码 其核心是管理国事访问的操作. 共享,可变的状态的訪问 - 前者表示多个线程訪问, 后者声明周期内发生改变. 线程安全性 核心概念是正确性.某个类的行为与其规范 ...
- XeTeX中文解决方案(temp)
临时记录一下XeTeX的中文解决方案.一些包的文档只是走马观花得到的解决方法,所以可能有诸多纰漏. 另个人还是比较看好LuaTeX,但是在里边鼓捣中文还是一团糟,等探索一下再回来补充. 我使用的包是x ...
- (大数据工程师学习路径)第二步 Vim编辑器----Vim快速入门
vim模式介绍 以下介绍内容来自维基百科Vim 从vi演生出来的Vim具有多种模式,这种独特的设计容易使初学者产生混淆.几乎所有的编辑器都会有插入和执行命令两种模式,并且大多数的编辑器使用了与Vim截 ...
- MLAPP——概率机器学习知识汇总
<机器学习>课程使用Kevin P. Murphy图书<Machine Learning A Probabilistic Perspective>本英语教材,本书从一个独特的数 ...