近期朋友几篇文章介绍了改填充导出的文章. 关联文章的地址

之前做项目的时候需要数据库导出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表格相关推荐

  1. java if在内存中_全面理解Java内存模型

    Java 内存模型的抽象 在 java 中,所有实例域.静态域和数组元素存储在堆内存中,堆内存在线程之间共享(本文使用"共享变量"这个术语代指实例域,静态域和数组元素).局部变量( ...

  2. java 对象 序列化 文件中_如何将一个java对象序列化到文件里

    1.准备要序列化的类User (这个类必须实现Serializable接口,该接口只起到一个标记作用,没有任何抽象方法) package cn.qdm.ceshi; import java.io.Se ...

  3. excel几个表合成一张_Excel中怎样把多张表格中的数据合并到一张表格中

    由于各种需要,我们往往会需要把多张表格中的数据内容合并成一张表格,那么应该怎么操作呢?我们以下为例: 下图中Sheet1是2011年的数据,sheet2是2012年的数据,最后要把它们合并在一张新表上 ...

  4. excel下拉列表联动_国家和城市的Excel下拉列表

    excel下拉列表联动 In Excel, you can use data validation to create drop down lists on a worksheet. Usually, ...

  5. 给表格中的文字设置字体以及设置表格样式

    表格是一种常见的数据呈现方式,它可以将数据按照一定的规则排列,使得数据更加直观易懂.而表格中的文字是表格的重要组成部分,字体的选择和样式的设置对于表格的呈现效果至关重要.本文将为大家介绍如何设置表格中 ...

  6. Java ME游戏开发中,碰撞检测算法在Java?ME中的实现(

    2019独角兽企业重金招聘Python工程师标准>>> 在Java ME游戏开发中,碰撞检测算法在Java?ME中的实现(百搜技术) 在Java ME游戏开发中,经常需要进行碰撞检测 ...

  7. 如何在WPS表格中插入一张图片,不影响表格格式

    如何在WPS表格中插入一张图片,不影响表格格式 首先把图片复制到表格中 然后将图片缩小到单元格相同大小 右键点击切换为嵌入单元格图片 然后点击图片旁边的+号就可以查看图片

  8. html%3ctd%3e文本自动换行,如何在表格中自动换行一列,并将表格大小设置为浏览器窗口...

    我有一个带有3个"组"的HTML表格,左侧,中间和右侧.如何在表格中自动换行一列,并将表格大小设置为浏览器窗口 +--------------------------------- ...

  9. java将jsp页面表格导出excel表格数据_简单的POI导出JSP页面表格数据到excel

    数据库中的equipment表数据: 读取数据库中表数据的代码TestExcel.java public class TestExcel extends BaseAction{/** * @param ...

最新文章

  1. 《Java虚拟机原理图解》5. JVM类加载器机制与类加载过程
  2. iOS 11开发教程(一)
  3. 关于在本地idea当中提交spark代码到远程的错误总结(第二篇)
  4. jstl核心标签使用
  5. Linux服务器集群系统(二)—— LVS的IP负载均衡技术
  6. 虚拟机拷贝出来_NETAPP存储虚拟机数据恢复案例
  7. 元祖python_python---tuple元祖
  8. 凹入表形式打印树形结构_【树形立方体】立方体有哪些特性?
  9. Python面试题汇总
  10. building for iOS simulator, but linking in object file built for tvOS, for architecture x86_64
  11. maven dependency problem 问题
  12. time_expire时间过短,刷卡至少1分钟,其他5分钟
  13. webpack安装使用教程
  14. Eeprom(at24c04)调试小记
  15. 鼠标移过,左右按钮显示
  16. CTFHub(UA注入和Refer注入)
  17. 音频声学基础一,基本概念介绍
  18. (五)k8sservice
  19. 李彦宏蝉联福布斯内地首富
  20. 自动化测试工程师简历

热门文章

  1. Unity3d:加载Format是RGB24位的图片失败(加载图片显示问号)
  2. 张侃:网络优化需实现五大转变
  3. P存储 EVA6000 服务器无法识别VG
  4. mysql查询 31到40_sql语句,取出表A中的第31条到40条记录
  5. ChatGPT:我围观了量子位MEET2023智能未来大会,还当了一回课代表
  6. c++ - 第9节 - vector类
  7. 个人为什么无法上架安卓 App 到国内应用商店?
  8. 通过非递归贝叶斯滤波实现室内环境下建筑平面图的行人惯性导航
  9. JAVA基础-eclipse
  10. 谈谈企业数字化转型必由之路--顶层设计