flex+java将数据库里的数据导出到指定目录下excel表里(poi)
数据写入到excel中采用的是Apache POI:
//java后台的一个工具类(该工具类适用于为不同字段添加,方便)
/* 下面这个方法是将list转换为Excel工作表的 */
public static HSSFWorkbook getWorkbook(List<ExporTable> list)
throws Exception {
HSSFWorkbook workbook = new HSSFWorkbook();
HSSFSheet sheet = workbook.createSheet("sheet1");
String[] columnNames;
String[] columnMethods;
// 首先,我们读取list中的第一个元素,根据它来确定工作表的列名,以及输出数据所对应的方法数组
ExporTable exp = list.get(0);
columnNames = exp.getColumnNames();
columnMethods = exp.getColumnMethods();
HSSFRow row = sheet.createRow(0); // 创建第1行,也就是输出表头
HSSFCell cell;
for (int i = 0; i < columnNames.length; i++) {
cell = row.createCell(i); // 创建第i列
cell.setCellValue(new HSSFRichTextString(columnNames[i]));
}
// 下面是输出各行的数据
for (int i = 0; i < list.size(); i++) {
exp = (ExporTable) list.get(i);
row = sheet.createRow(i + 1);// 创建第i+1行
for (int j = 0; j < columnMethods.length; j++) {
cell = row.createCell(j);// 创建第j列
Method method;
method = exp.getClass().getMethod(columnMethods[j]); // 这里用到了反射机制,通过方法名来取得对应方法返回的结果对象
Object obj = method.invoke(exp);
if (obj != null) {
cell.setCellValue(obj.toString());
}
}
}
return workbook;
}
/**
* 将ExportBean转换为Excel工作表
*
* @param exportBeans 集合,每个元素代表一个sheet
* @return
* @throws Exception
*/
public static HSSFWorkbook getWorkbooks(ExportBean<?>... exportBeans)
throws Exception {
HSSFWorkbook workbook = new HSSFWorkbook();
HSSFCellStyle cellStyle = workbook.createCellStyle();
cellStyle.setDataFormat(HSSFDataFormat.getBuiltinFormat("m/d/yy h:mm"));
for (ExportBean<?> eb : exportBeans) {
HSSFSheet sheet = workbook.createSheet(eb.getSheetName());
String[] headers = eb.getHeaders();
HSSFRow row = sheet.createRow(0); // 创建第1行,也就是输出表头
HSSFCell cell;
// 设置表头粗体样式
HSSFFont font = workbook.createFont();
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
HSSFCellStyle cellStyleHeader = workbook.createCellStyle();
cellStyleHeader.setFont(font);
for (int i = 0; i < headers.length; i++) {
// 设置列宽
sheet.setColumnWidth((short) i, 6000);
cell = row.createCell(i); // 创建第i列
cell.setCellStyle(cellStyleHeader);
cell.setCellValue(new HSSFRichTextString(headers[i]));
}
String[] getMethods = eb.getGetMethods();
List rows = eb.getRows();
// 下面是输出各行的数据
for (int i = 0; i < rows.size(); i++) {
Object rowData = rows.get(i);
row = sheet.createRow(i + 1);// 创建第i+1行
for (int j = 0; j < getMethods.length; j++) {
cell = row.createCell(j);// 创建第j列
// cell.setCellStyle(cellStyle);
Method method = null;
try {
method = rowData.getClass().getMethod(getMethods[j]); // 这里用到了反射机制,通过方法名来取得对应方法返回的结果对象
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
Object obj = method.invoke(rowData);
if (obj != null) {
// cell.setCellType(HSSFCell.);
if (obj instanceof java.util.Date) {
cell.setCellValue((java.util.Date) obj);
cell.setCellStyle(cellStyle);
} else if (obj instanceof BigDecimal) {
cell.setCellValue(((BigDecimal) obj).longValue());
} else {
cell.setCellValue(obj.toString());
}
}
}
}
}
return workbook;
}
// 将Workbook写入到InputStream
public static InputStream workbook2InputStream(HSSFWorkbook workbook,
ByteArrayOutputStream baos, String fileName) throws Exception {
workbook.write(baos);
baos.flush();
byte[] aa = baos.toByteArray();
InputStream excelStream = new ByteArrayInputStream(aa, 0, aa.length);
return excelStream;
}
// 将Workbook写入到byte数组
public static byte[] workbook2ByteArray(HSSFWorkbook workbook,
ByteArrayOutputStream baos) throws Exception {
workbook.write(baos);
baos.flush();
byte[] aa = baos.toByteArray();
return aa;
}
/**
* 考虑到多sheet情况暂时加个数据结构封装下吧
* @author 王云超
* 时间 2014-7-16 下午5:30:23
*/
public class ExportBean<T> {
private String sheetName ; //sheet名称
private String[] headers; //表头
private String[] getMethods; //方法集合
private List<T> rows; //数据行
public String[] getGetMethods() {
return getMethods;
}
public void setGetMethods(String[] getMethods) {
this.getMethods = getMethods;
}
public String getSheetName() {
return sheetName;
}
public void setSheetName(String sheetName) {
this.sheetName = sheetName;
}
public String[] getHeaders() {
return headers;
}
public void setHeaders(String[] headers) {
this.headers = headers;
}
public List<T> getRows() {
return rows;
}
public void setRows(List<T> rows) {
this.rows = rows;
}
}
//java代码:
public void DbToExcels(){
byte[] bytes = null;
try {
ExportBean<CirCuit> eb = new ExportBean<CirCuit>();
eb.setHeaders(new String[] { "id","名字","时间" });
eb.setGetMethods(new String[] {"getId","getCircuit_type","getSystem_id"});
List<CirCuit> list = cirCuitBo.findAll();
eb.setRows(list);
eb.setSheetName("信息");
HSSFWorkbook workbook = PoiUtil.getWorkbooks(eb);
ByteArrayOutputStream baos = new ByteArrayOutputStream();
bytes = PoiUtil.workbook2ByteArray(workbook, baos);
} catch (Exception e) {
e.printStackTrace();
log.error("导出数据失败",e);
}
return bytes;
}
//flex代码:
Alert.show("是否要保存文件!","提示",Alert.YES|Alert.NO,null,function(evt){
if(evt.detail == Alert.YES){
var fileRef:FileReference = new FileReference();
fileRef.save(data.result,"信息表.xls");
}
});
flex+java将数据库里的数据导出到指定目录下excel表里(poi)的更多相关文章
- File操作-将数据库里的数据写入到指定路径的txt文件里
package com.Cristin.File;//将数据库里的数据写入到指定路径的txt文件里 import java.io.File;import java.io.FileOutputStrea ...
- 【Java】数据库查询的数据直接以指定文件类型下载到本地(弹出下载框)
欲实现的功能目标:当点击下图的导出数据文件时弹出文件下载框,默认csv格式,用户自定义下载的本地路径 遇到的问题: 1.项目之前做过一次下载,但是是使用了本地文件模板.用输入流读取文件模板,插入数据, ...
- java 跨数据库导入大数据
java 跨数据库导入大数据 /** * java程序跨服务器跨数据库批量导入导出百万级数据 * @param args * @throws Exception */ public static vo ...
- Django数据操作F和Q、model多对多操作、Django中间件、信号、读数据库里的数据实现分页
models.tb.objects.all().using('default'),根据using来指定在哪个库里查询,default是settings中配置的数据库的连接名称. 外话:django中引 ...
- TreeView树形控件递归绑定数据库里的数据
TreeView树形控件递归绑定数据库里的数据. 第一种:性能不好 第一步:数据库中查出来的表,字段名分别为UNAME(显示名称),DID(关联数据),UTYPE(类型) 第二步:前台代码 <% ...
- 使用C#或javascript将Table里的数据导出到Excel
原文:使用C#或javascript将Table里的数据导出到Excel Demo效果图: 用C#将Table数据导出Excel: 本方法已经将导出excel做成分部视图,引用时只需在视图中使用如下代 ...
- 如何将存储在MongoDB数据库中的数据导出到Excel中?
将MongoDB数据库中的数据导出到Excel中,只需以下几个步骤: (1)首先,打开MongoDB安装目录下的bin文件夹,(C:\Program Files (x86)\MongoDB\Serve ...
- [软件共享]将数据库中的数据导出为SQL脚本
可以直接将数据库中的数据导出为脚本,并可以自己设置过滤条件.使用方法很简单,不在多说了.下面是软件截图.123 下载:http://files.cnblogs.com/pw/mssql2.rar
- Java基础---Java---IO流-----File 类、递归、删除一个带内容的目录、列出指定目录下文件夹、FilenameFilte
File 类 用来将文件或者文件夹封装成对象 方便对文件与文件夹进行操作. File对象可以作为参数传递给流的构造函数 流只用操作数据,而封装数据的文件只能用File类 File类常见方法: 1.创建 ...
随机推荐
- JFrame面板
1.可见性与透明性 可见性:当面板不可见时,则该面板中包含的组件会无法显示. 透明性:若该面板是可见且透明的,那么只是面板会透明(比如面板的背景色无法看到),面板上的组件仍会显示. 注:可见性通过se ...
- B+树索引和哈希索引的区别——我在想全文搜索引擎为啥不用hash索引而非得使用B+呢?
哈希文件也称为散列文件,是利用哈希存储方式组织的文件,亦称为直接存取文件.它类似于哈希表,即根据文件中关键字的特点,设计一个哈希函数和处理冲突的方法,将记录哈希到存储设备上. 在哈希文件中,是使用一个 ...
- YanYan Self Introduction
My Website: http://finehappy.com/
- android webview web里面的数据透传到java以及java的数据透传到web
详见: http://tutorials.jenkov.com/android/android-web-apps-using-android-webview.html#android-web-app- ...
- linux 安装软件,卸载软件 等的几种方式
安装软件的步骤和基本原则: 1. rpm安装: 定义: rpm是由红帽公司开发的软件包管理方式,使用rpm我们可以方便的进行软件的安装.查询.卸载.升级等工作.但是rpm软件包之间的依赖性问题往往会很 ...
- centos ssh配置使用
配置 数据阶梯 CentOS SSH配置 默认CentOS已经安装了OpenSSH,即使你是最小化安装也是如此.所以这里就不介绍OpenSSH的安装了. SSH配置: 1.修改vi /etc/ssh/ ...
- Windows下为64位的python3.4.3安装numpy
貌似现在没有python3.x的numpy 64位.exe安装包只有.whl的(也可能是我没找到)只能在终端下安装 1.到官网https://www.python.org/downloads/下载py ...
- POJ 3691 AC自动机上的dp
题目大意: 给定一些不合理的DNA序列,再给一段较长的dna序列,问最少修改几次可以使序列中不存在任何不合理序列,不能找到修改方法输出-1 这里你修改某一个点的DNA可能会影响后面,我们不能单纯的找匹 ...
- [转]VS2005 Debug时提示"没有找到MSVCR80D.dll"的解决办法
总结各种解决方法如下: 原因:(不知道在说啥)由于VS.net 2005 采用了一种新的DLL方案,搞成一个exe还要配有一个manifest文件(一般在嵌入文件里了,所以看不到,不过也可以不嵌入,这 ...
- 完美替换win8.1 x64默认雅黑为宋体方法
由于显示器不好,安装win8.1 x64系统后,系统默认的雅黑字体实在是看不习惯, 时间稍一常眼睛就发累,还是一直用的xp宋体好,于是寻思着能不能将默认雅黑换成宋体. 网上倒是搜出了许多win7的修改 ...