Java导出数据为EXCEL的两种方式JXL和POI
JXL和POI导出数据方式的比较
POI支持excel2003和2007,而jxl只支持excel2003。
下面为测试代码:
- public class TestCondition {
- /**
- * 生成的记录条数
- */
- public static final int RECORD_COUNT = 21000;
- /**
- * 模板文件
- */
- public static final String TEMPLATE_FILE = "E:/MyKernelPlatformWorkspace/Template/query_order.xls";
- /**
- * JXL生成文件位置
- */
- public static final String JXL_TARGET_FILE_NAME = "E:/MyKernelPlatformWorkspace/Template/target/jxl_order.xls";
- /**
- * POI生成文件位置
- */
- public static final String POI_TARGET_FILE_NAME = "E:/MyKernelPlatformWorkspace/Template/target/poi_order.xls";
- /**
- * JXL临时文件位置
- */
- public static final String JXL_TEMP_DIR = "E:/MyKernelPlatformWorkspace/Template/temp";
- }
然后在此测试条件下编写JXL和POI的测试类,首先是JXL的
- public class JXLExcel {
- /**
- * 起始行
- */
- private static final int start_row = 3;
- private WorkbookSettings settings;
- private File target;
- public JXLExcel() {
- this.settings = new WorkbookSettings();
- //设定JXL在生成excel文件时使用临时文件
- settings.setUseTemporaryFileDuringWrite(true);
- settings.setTemporaryFileDuringWriteDirectory(new File(TestCondition.JXL_TEMP_DIR));
- this.target = new File(TestCondition.JXL_TARGET_FILE_NAME);
- }
- public void execute() throws Exception {
- // 读入模板文件
- Workbook template = Workbook.getWorkbook(new File(TestCondition.TEMPLATE_FILE));
- WritableWorkbook worbook = Workbook.createWorkbook(target, template, settings);
- // 获取第一个sheet
- WritableSheet sheet = worbook.getSheet(0);
- Random random = new Random();
- // 循环写入数据
- for(int i = 0;i < TestCondition.RECORD_COUNT;i++) {
- int row = i + start_row;
- sheet.insertRow(row);
- Label col1 = new Label(0, row, String.valueOf(i + 1));
- Label col2 = new Label(1, row, String.valueOf(random.nextLong()));
- Label col3 = new Label(2, row, String.valueOf(random.nextLong()));
- Label col4 = new Label(3, row, "merchant" + (i +1));
- jxl.write.Number col5 = new Number(4, row, random.nextDouble());
- jxl.write.Number col6 = new Number(5, row, random.nextDouble());
- jxl.write.Number col7 = new Number(6, row, random.nextDouble());
- jxl.write.Number col8 = new Number(7, row, random.nextDouble());
- Label col9 = new Label(8, row, String.valueOf(random.nextLong()));
- Label col10 = new Label(9, row, "PAY");
- Label col11 = new Label(10, row, "POS");
- Label col12 = new Label(11, row, "2010-09-03 12:45:13");
- Label col13 = new Label(12, row, "2010-09-09 12:45:13");
- Label col14 = new Label(13, row, "interface" + (i + 1));
- Label col15 = new Label(14, row, "18701001830");
- Label col16 = new Label(15, row, "ccbc");
- Label col17 = new Label(16, row, String.valueOf(random.nextLong()));
- Label col18 = new Label(17, row, String.valueOf(random.nextLong()));
- jxl.write.Number col19 = new Number(18, row, random.nextDouble());
- jxl.write.Number col20 = new Number(19, row, random.nextDouble());
- Label col21 = new Label(20, row, "payer" + (i + 1));
- Label col22 = new Label(21, row, String.valueOf(random.nextLong()));
- Label col23 = new Label(22, row, "192.168.1.1");
- Label col24 = new Label(23, row, "192.168.1.1");
- sheet.addCell(col1);
- sheet.addCell(col2);
- sheet.addCell(col3);
- sheet.addCell(col4);
- sheet.addCell(col5);
- sheet.addCell(col6);
- sheet.addCell(col7);
- sheet.addCell(col8);
- sheet.addCell(col9);
- sheet.addCell(col10);
- sheet.addCell(col11);
- sheet.addCell(col12);
- sheet.addCell(col13);
- sheet.addCell(col14);
- sheet.addCell(col15);
- sheet.addCell(col16);
- sheet.addCell(col17);
- sheet.addCell(col18);
- sheet.addCell(col19);
- sheet.addCell(col20);
- sheet.addCell(col21);
- sheet.addCell(col22);
- sheet.addCell(col23);
- sheet.addCell(col24);
- }
- worbook.write();
- worbook.close();
- }
- }
执行Main函数
- public class JXLMain {
- /**
- * 描述:
- * @param args
- * @throws Exception
- */
- public static void main(String[] args) throws Exception {
- long jxlStart = System.currentTimeMillis();
- JXLExcel jxl = new JXLExcel();
- jxl.execute();
- long jxlStop = System.currentTimeMillis();
- System.out.println("jxl takes : " + (jxlStop - jxlStart)/1000 + " seconds.");
- }
然后是POI的
public class POIExcel {
- /**
- * 起始行
- */
- private static final int start_row = 3;
- public void execute() throws Exception {
- // 读入模板文件
- InputStream is = new FileInputStream(TestCondition.TEMPLATE_FILE);
- POIFSFileSystem poifsFileSystem = new POIFSFileSystem(is);
- HSSFWorkbook workbook = new HSSFWorkbook(poifsFileSystem);
- // 获取第一个sheet
- HSSFSheet sheet = workbook.getSheetAt(0);
- Random random = new Random();
- // 将模板的最后两行移动
- sheet.shiftRows(3, 4, TestCondition.RECORD_COUNT);
- OutputStream os = new FileOutputStream(
- TestCondition.POI_TARGET_FILE_NAME);
- // 循环写入数据
- for (int i = 0; i < TestCondition.RECORD_COUNT; i++) {
- int rowNum = i + start_row;
- HSSFRow row = sheet.createRow(rowNum);
- HSSFCell cell1 = row.createCell(0);
- cell1.setCellValue(i + 1);
- HSSFCell cell2 = row.createCell(1);
- cell2.setCellValue(String.valueOf(random.nextLong()));
- HSSFCell cell3 = row.createCell(2);
- cell3.setCellValue(String.valueOf(random.nextLong()));
- HSSFCell cell4 = row.createCell(3);
- cell4.setCellValue("merchant" + (i +1));
- HSSFCell cell5 = row.createCell(4);
- cell5.setCellValue(random.nextDouble());
- HSSFCell cell6 = row.createCell(5);
- cell6.setCellValue(random.nextDouble());
- HSSFCell cell7 = row.createCell(6);
- cell7.setCellValue(random.nextDouble());
- HSSFCell cell8 = row.createCell(7);
- cell8.setCellValue(random.nextDouble());
- HSSFCell cell9 = row.createCell(8);
- cell9.setCellValue(String.valueOf(random.nextLong()));
- HSSFCell cell10 = row.createCell(9);
- cell10.setCellValue("PAY");
- HSSFCell cell11 = row.createCell(10);
- cell11.setCellValue("POS");
- HSSFCell cell12 = row.createCell(11);
- cell12.setCellValue(new Date());
- HSSFCell cell13 = row.createCell(12);
- cell13.setCellValue(new Date());
- HSSFCell cell14 = row.createCell(13);
- cell14.setCellValue("interface" + (i + 1));
- HSSFCell cell15 = row.createCell(14);
- cell15.setCellValue("18701001830");
- HSSFCell cell16 = row.createCell(15);
- cell16.setCellValue("ccbc");
- HSSFCell cell17 = row.createCell(16);
- cell17.setCellValue(String.valueOf(random.nextLong()));
- HSSFCell cell18 = row.createCell(17);
- cell18.setCellValue(String.valueOf(random.nextLong()));
- HSSFCell cell19 = row.createCell(18);
- cell19.setCellValue(random.nextDouble());
- HSSFCell cell20 = row.createCell(19);
- cell20.setCellValue(random.nextDouble());
- HSSFCell cell21 = row.createCell(20);
- cell21.setCellValue("payer" + (i + 1));
- HSSFCell cell22 = row.createCell(21);
- cell22.setCellValue(String.valueOf(random.nextLong()));
- HSSFCell cell23 = row.createCell(22);
- cell23.setCellValue("192.168.1.1");
- HSSFCell cell24 = row.createCell(23);
- cell24.setCellValue("192.168.1.1");
- }
- workbook.write(os);
- os.close();
- }
执行Main函数
- public class POIMain {
- /**
- * 描述:
- * @param args
- * @throws Exception
- */
- public static void main(String[] args) throws Exception {
- long jxlStart = System.currentTimeMillis();
- POIExcel poi = new POIExcel();
- poi.execute();
- long jxlStop = System.currentTimeMillis();
- System.out.println("poi takes : " + (jxlStop - jxlStart)/1000 + " seconds.");
- }
- }
转:http://tianwenbo.iteye.com/blog/1485654
Java导出数据为EXCEL的两种方式JXL和POI的更多相关文章
- mysql导出数据到excel的两种方式
使用第一种方式如果数据中有换行符的话会自动换行,但使用第二种方式就不会出现这种效果了.两种方式自己选择哈 1:select * from into outfile 'c:/Users/a.xls' t ...
- Java EXCEL导入的两种方式JXL和POI
Excel导入有两个方法:JXL 和POI 1.JXL解析Excel public class JxlReadExcel { /** * JXL解析Excel * @author Da ...
- java分段加载数据,循环和递归两种方式
package org.jimmy.autosearch2019.test; import java.util.ArrayList; public class Test20190328 { priva ...
- Delphi 导出数据至Excel的7种方法【转】
一; delphi 快速导出excel uses ComObj,clipbrd; function ToExcel(sfilename:string; ADOQuery:TADOQuery): ...
- Delphi 导出数据至Excel的7种方法
一; delphi 快速导出excel uses ComObj,clipbrd; function ToExcel(sfilename:string; ADOQuery:TADOQuery):bool ...
- Java并发--线程间协作的两种方式:wait、notify、notifyAll和Condition
在前面我们将了很多关于同步的问题,然而在现实中,需要线程之间的协作.比如说最经典的生产者-消费者模型:当队列满时,生产者需要等待队列有空间才能继续往里面放入商品,而在等待的期间内,生产者必须释放对临界 ...
- 遍历Map集合:java.util.Map.Entry、KeySet两种方式
遍历Map集合的两种方式: 1.用KeySet Map.keySet(),返回一个存放所有key的set集合,通过遍历集合,根据key值取出所有的value值. Map<String,Strin ...
- Android提交数据到服务器的两种方式四种方法
本帖最后由 yanghe123 于 2012-6-7 09:58 编辑 Android应用开发中,会经常要提交数据到服务器和从服务器得到数据,本文主要是给出了利用http协议采用HttpClient方 ...
- python利用mongodb上传图片数据 : GridFS 与 bson两种方式
利用mongodb保存图片通常有两种方法,一种是将图片数据转化为二进制作为字典的键值对进行保存,另一种是利用mongodb提供的GridFS进行保存,两者各有利弊.性能方面的优劣未曾测试,无法进行评价 ...
随机推荐
- 指定WebService访问的语言
场景: 在访问ERP发布的WebService时,由于其指定了访问语言,导致不指定访问语言时,会有部分数据丢失. 解决: 通过WSDL工具生成代理类后,再次对其中的GetWebRequest方法进行重 ...
- svn: E200030: sqlite[S10]: disk I/O error
1. 经遇到的问题,它出现(在我的情况下,至少)要与TortoiseSVN的相互作用.禁用TortoiseSVN的图标缓存(设置>图标重载>缓存“无”>申请)拥有的一切工作就好了 ( ...
- U3d中实现A*寻路,附源文件
图片看不清楚,请点击看大图 http://pan.baidu.com/s/1pKwmOYn 写了好多,没保存,哎哎哎 空格键开始移动
- POJ 4046 Sightseeing 枚举+最短路 好题
有n个节点的m条无向边的图,节点编号为1~n 然后有点权和边权,给出q个询问,每一个询问给出2点u,v 输出u,v的最短距离 这里的最短距离规定为: u到v的路径的所有边权+u到v路径上最大的一个点权 ...
- php之面向对象
<?php declare(encoding='UTF-8'); class Site{ /*成员变量*/ var $url; var $title = "gunduzi" ...
- Tomcat启动过程原理详解
基于Java的Web 应用程序是 servlet.JSP 页面.静态页面.类和其他资源的集合,它们可以用标准方式打包,并运行在来自多个供应商的多个容器.Web 应用程序存在于结构化层次结构的目录中,该 ...
- 使用Jenkins搭建持续集成服务
1. 什么是持续集成 持续集成 (Continuous Integration, 简称 CI) 是软件工程中的一种实践, 用于将开发人员不同阶段的工作成果集成起来, 通常一天之中会进行多次. 持续集成 ...
- Nginx+Tomcat+Keepalived+Memcache 负载均衡动静分离技术
一.概述 Nginx 作负载均衡器的优点许多,简单概括为: ①实现了可弹性化的架构,在压力增大的时候可以临时添加Tomcat服务器添加到这个架构里面去; ②upstream具有负载均衡能力,可以自动判 ...
- [Java] 读写字节数据,过滤流DataOutputStream和DataInputStream
package test.stream; import java.io.DataInputStream; import java.io.DataOutputStream; import java.io ...
- Understanding Asynchronous IO With Python 3.4's Asyncio And Node.js
[转自]http://sahandsaba.com/understanding-asyncio-node-js-python-3-4.html Introduction I spent this su ...