java填充excel表格中_填充导出Java导出excel表格
近期朋友几篇文章介绍了改填充导出的文章. 关联文章的地址
之前做项目的时候需要数据库导出excel格式,由于项目赶没实现,现在分享下如何用java导出excel。话不多说案例如下:
首先要做的是导入一个jxl的包,网上很多。首先是不连接数据库数据
package jxlTest;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import jxl.*;
import jxl.format.Alignment;
import jxl.format.Border;
import jxl.format.BorderLineStyle;
import jxl.format.CellFormat;
import jxl.write.Boolean;
import jxl.write.Label;
import jxl.write.Number;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
public class JXLExample {
/**
* 数据库导出至Excel表格
*/
public static void main(String[] args) {
// 准备设置excel任务表的标题
String[] title = {"编号","产品名称","产品价格","产品数量","生产日期","产地","是否出口"};
try {
// 获得开始时光
long start = System.currentTimeMillis();
// 输出的excel的路径
String filePath = "e:\\testJXL.xls";
// 创建Excel任务薄
WritableWorkbook wwb;
// 新建立一个jxl文件,即在e盘下生成testJXL.xls
OutputStream os = new FileOutputStream(filePath);
wwb=Workbook.createWorkbook(os);
// 添加第一个任务表并设置第一个Sheet的名字
WritableSheet sheet = wwb.createSheet("产品清单", 0);
Label label;
for(int i=0;i
// Label(x,y,z) 代表单元格的第x+1列,第y+1行, 内容z
// 在Label对象的子对象中指明单元格的位置和内容
label = new Label(i,0,title[i]);
// 将定义好的单元格添加到任务表中
sheet.addCell(label);
}
// 下面是填充数据
/*
* 保存数字到单元格,需要应用jxl.write.Number
* 必须应用其完整路径,否则会涌现错误
* */
// 填充产品编号
jxl.write.Number number = new jxl.write.Number(0,1,20071001);
sheet.addCell(number);
// 填充产品名称
label = new Label(1,1,"金鸽瓜子");
sheet.addCell(label);
/*
* 定义对于表现金额的公共格式
* jxl会自动实现四舍五入
* 例如 2.456会被格式化为2.46,2.454会被格式化为2.45
* */
jxl.write.NumberFormat nf = new jxl.write.NumberFormat("#.##");
jxl.write.WritableCellFormat wcf = new jxl.write.WritableCellFormat(nf);
// 填充产品价格
jxl.write.Number nb = new jxl.write.Number(2,1,2.45,wcf);
sheet.addCell(nb);
// 填充产品数量
jxl.write.Number numb = new jxl.write.Number(3,1,200);
sheet.addCell(numb);
/*
* 定义表现日期的公共格式
* 如:yyyy-MM-dd hh:mm
* */
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
String newdate = sdf.format(new Date());
// 填充生产日期
label = new Label(4,1,newdate);
sheet.addCell(label);
// 填充产地
label = new Label(5,1,"陕西西安");
sheet.addCell(label);
/*
* 表现布尔值
* */
jxl.write.Boolean bool = new jxl.write.Boolean(6,1,true);
sheet.addCell(bool);
/*
* 合并单元格
* 通过writablesheet.mergeCells(int x,int y,int m,int n);来实现的
* 表示将从第x+1列,y+1行到m+1列,n+1行合并
*
* */
sheet.mergeCells(0,3,2,3);
label = new Label(0,3,"合并了三个单元格");
每日一道理
盈盈月光,我掬一杯最清的;落落余辉,我拥一缕最暖的;灼灼红叶,我拾一片最热的;萋萋芳草,我摘一束最灿的;漫漫人生,我要采撷世间最重的———毅力。
sheet.addCell(label);
/*
*
* 定义公共字体格式
* 通过获取一个字体的款式来作为模板
* 首先通过web.getSheet(0)获得第一个sheet
* 然后获得第一个sheet的第二列,第一行也就是"产品名称"的字体
* */
CellFormat cf = wwb.getSheet(0).getCell(1, 0).getCellFormat();
WritableCellFormat wc = new WritableCellFormat();
// 设置居中
wc.setAlignment(Alignment.CENTRE);
// 设置边框线
wc.setBorder(Border.ALL, BorderLineStyle.THIN);
// 设置单元格的背景颜色
wc.setBackground(jxl.format.Colour.RED);
label = new Label(1,5,"字体",wc);
sheet.addCell(label);
// 写入数据
wwb.write();
// 关闭文件
wwb.close();
long end = System.currentTimeMillis();
System.out.println("----实现该操纵共用的时光是:"+(end-start)/1000);
} catch (Exception e) {
System.out.println("---涌现异常---");
e.printStackTrace();
}
}
}
其次是关联到oracle的数据库数据
package zjx;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import dao.ProductDao;
import dao.impl.ProductDaoImpl;
import entity.Product;
import jxl.*;
import jxl.format.Alignment;
import jxl.format.Border;
import jxl.format.BorderLineStyle;
import jxl.format.CellFormat;
import jxl.write.Boolean;
import jxl.write.Label;
import jxl.write.Number;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
public class DemoXls {
/**
* 数据库导出至Excel表格
*/
public static void main(String[] args) {
// 准备设置excel任务表的标题
String[] title = {"编号","产品名称","产品类型","计量类型"};
try {
// 获得开始时光
long start = System.currentTimeMillis();
// 输出的excel的路径
String filePath = "e:\\testJXL2.xls";
// 创建Excel任务薄
WritableWorkbook wwb;
// 新建立一个jxl文件,即在e盘下生成testJXL.xls
OutputStream os = new FileOutputStream(filePath);
wwb=Workbook.createWorkbook(os);
// 添加第一个任务表并设置第一个Sheet的名字
WritableSheet sheet = wwb.createSheet("产品清单", 0);
Label label;
for(int i=0;i
// Label(x,y,z) 代表单元格的第x+1列,第y+1行, 内容z
// 在Label对象的子对象中指明单元格的位置和内容
label = new Label(i,0,title[i]);
// 将定义好的单元格添加到任务表中
sheet.addCell(label);
}
// 下面是填充数据
/*
* 保存数字到单元格,需要应用jxl.write.Number
* 必须应用其完整路径,否则会涌现错误
* */
ProductDao dao=new ProductDaoImpl();
List list=dao.queryAll();
for(int i=0;i
// 填充产品编号
jxl.write.Number number = new jxl.write.Number(0,i+1,list.get(i).getProductId());
sheet.addCell(number);
// 填充产品名称
label = new Label(1,i+1,list.get(i).getProductName());
sheet.addCell(label);
jxl.write.Number type = new jxl.write.Number(2,i+1,list.get(i).getProductTypeId());
sheet.addCell(type);
jxl.write.Number measure = new jxl.write.Number(3,i+1,list.get(i).getMeasureTypeId());
sheet.addCell(measure);
}
// 写入数据
wwb.write();
// 关闭文件
wwb.close();
long end = System.currentTimeMillis();
System.out.println("----实现该操纵共用的时光是:"+(end-start)/1000);
} catch (Exception e) {
System.out.println("---涌现异常---");
e.printStackTrace();
}
}
}
希望能帮助有需要的人
文章结束给大家分享下程序员的一些笑话语录:
打赌
飞机上,一位工程师和一位程序员坐在一起。程序员问工程师是否乐意和他一起玩一种有趣的游戏。工程师想睡觉,于是他很有礼貌地拒绝了,转身要睡觉。程序员坚持要玩并解释说这是一个非常有趣的游戏:"我问你一个问题,如果你不知道答案,我付你5美元。然后你问我一个问题,如果我答不上来,我付你5美元。"然而,工程师又很有礼貌地拒绝了,又要去睡觉。 程序员这时有些着急了,他说:"好吧,如果你不知道答案,你付5美元;如果我不知道答案,我付50美元。"果然,这的确起了作用,工程师答应了。程序员就问:"从地球到月球有多远?"工程师一句话也没有说,给了程序员5美元。 现在轮到工程师了,他问程序员:"什么上山时有三条腿,下山却有四条腿?"程序员很吃惊地看着工程师,拿出他的便携式电脑,查找里面的资料,过了半个小时,他叫醒工程师并给了工程师50美元。工程师很礼貌地接过钱又要去睡觉。程序员有些恼怒,问:"那么答案是什么呢?"工程师什么也没有说,掏出钱包,拿出5美元给程序员,转身就去睡觉了。
---------------------------------
原创文章 By
填充和导出
---------------------------------
java填充excel表格中_填充导出Java导出excel表格相关推荐
- java if在内存中_全面理解Java内存模型
Java 内存模型的抽象 在 java 中,所有实例域.静态域和数组元素存储在堆内存中,堆内存在线程之间共享(本文使用"共享变量"这个术语代指实例域,静态域和数组元素).局部变量( ...
- java 对象 序列化 文件中_如何将一个java对象序列化到文件里
1.准备要序列化的类User (这个类必须实现Serializable接口,该接口只起到一个标记作用,没有任何抽象方法) package cn.qdm.ceshi; import java.io.Se ...
- excel几个表合成一张_Excel中怎样把多张表格中的数据合并到一张表格中
由于各种需要,我们往往会需要把多张表格中的数据内容合并成一张表格,那么应该怎么操作呢?我们以下为例: 下图中Sheet1是2011年的数据,sheet2是2012年的数据,最后要把它们合并在一张新表上 ...
- excel下拉列表联动_国家和城市的Excel下拉列表
excel下拉列表联动 In Excel, you can use data validation to create drop down lists on a worksheet. Usually, ...
- 给表格中的文字设置字体以及设置表格样式
表格是一种常见的数据呈现方式,它可以将数据按照一定的规则排列,使得数据更加直观易懂.而表格中的文字是表格的重要组成部分,字体的选择和样式的设置对于表格的呈现效果至关重要.本文将为大家介绍如何设置表格中 ...
- Java ME游戏开发中,碰撞检测算法在Java?ME中的实现(
2019独角兽企业重金招聘Python工程师标准>>> 在Java ME游戏开发中,碰撞检测算法在Java?ME中的实现(百搜技术) 在Java ME游戏开发中,经常需要进行碰撞检测 ...
- 如何在WPS表格中插入一张图片,不影响表格格式
如何在WPS表格中插入一张图片,不影响表格格式 首先把图片复制到表格中 然后将图片缩小到单元格相同大小 右键点击切换为嵌入单元格图片 然后点击图片旁边的+号就可以查看图片
- html%3ctd%3e文本自动换行,如何在表格中自动换行一列,并将表格大小设置为浏览器窗口...
我有一个带有3个"组"的HTML表格,左侧,中间和右侧.如何在表格中自动换行一列,并将表格大小设置为浏览器窗口 +--------------------------------- ...
- java将jsp页面表格导出excel表格数据_简单的POI导出JSP页面表格数据到excel
数据库中的equipment表数据: 读取数据库中表数据的代码TestExcel.java public class TestExcel extends BaseAction{/** * @param ...
最新文章
- 《Java虚拟机原理图解》5. JVM类加载器机制与类加载过程
- iOS 11开发教程(一)
- 关于在本地idea当中提交spark代码到远程的错误总结(第二篇)
- jstl核心标签使用
- Linux服务器集群系统(二)—— LVS的IP负载均衡技术
- 虚拟机拷贝出来_NETAPP存储虚拟机数据恢复案例
- 元祖python_python---tuple元祖
- 凹入表形式打印树形结构_【树形立方体】立方体有哪些特性?
- Python面试题汇总
- building for iOS simulator, but linking in object file built for tvOS, for architecture x86_64
- maven dependency problem 问题
- time_expire时间过短,刷卡至少1分钟,其他5分钟
- webpack安装使用教程
- Eeprom(at24c04)调试小记
- 鼠标移过,左右按钮显示
- CTFHub(UA注入和Refer注入)
- 音频声学基础一,基本概念介绍
- (五)k8sservice
- 李彦宏蝉联福布斯内地首富
- 自动化测试工程师简历