Java生成excel导出文件(使用poi+JXL)
1.使用poi生成文件
package com.mi.entity;
import java.util.Date;
public class Student {
private int id;
private String name;
private int age;
private Date birth;
public Student(int id, String name, int age, Date birth) {
super();
this.id = id;
this.name = name;
this.age = age;
this.birth = birth;
}
}
生成excel文件代码
package com.mi.util; import java.io.File;
import java.io.FileOutputStream;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.List; import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook; import com.mi.entity.Student; public class CreateSimpleExcelToDisk { /**
* 手工创建一个包含student的list
* @return
* @throws Exception
*/
private static List<Student> getStudent() throws Exception {
List<Student> list = new ArrayList<>();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-mm-dd");
Student user1 = new Student(1, "张三", 16, sdf.parse("1997-03-12"));
Student user2 = new Student(2, "李四", 17, sdf.parse("1996-08-12"));
Student user3 = new Student(3, "王五", 26, sdf.parse("1985-11-12"));
list.add(user1);
list.add(user2);
list.add(user3); return list;
}
public static void main(String[] args) throws Exception {
//第一步,创建一个webbook文件,对应一个excel文件
HSSFWorkbook wb = new HSSFWorkbook();
//第二部,在excel中添加一个sheet工作簿,参数为该工作簿名字,不写为默认;
HSSFSheet sheet = wb.createSheet("学生表1");
//第三部,做sheet中添加表头第0行,注意老版本poi对excel的行数列数有限制short
HSSFRow row = sheet.createRow((int)0);
//第四部,创建单元格表头 设置表头居中
HSSFCellStyle style = wb.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);//创建一个居中格式 //创建具体盛放数据的单元格,可以考虑把cell抽成共通对象去使用
HSSFCell cell = row.createCell((int) 0);
cell.setCellValue("学号");
cell = row.createCell((int) 1);
cell.setCellValue("姓名");
cell = row.createCell((int) 2);
cell.setCellValue("年龄");
cell = row.createCell((int) 3);
cell.setCellValue("生日"); //第五部,写入实体数据 实际应用中这些数据应该是从数据库中得到
List<Student> list = CreateSimpleExcelToDisk.getStudent();
for(int i=0;i<list.size();i++){
//每次新建一行然后在新行中插入list中的数据对象,有点繁琐,也许有更好的封装方法,留待后看
row = sheet.createRow((int)i+1);
row.createCell((int)0).setCellValue(list.get(i).getId());
row.createCell((int)1).setCellValue(list.get(i).getName());
row.createCell((int)2).setCellValue(list.get(i).getAge());
row.createCell((int)3).setCellValue(new SimpleDateFormat("yyyy-mm-dd").format(list.get(i).getBirth())); } //第六部,将文件保存到指定位置
FileOutputStream fout = new FileOutputStream("D:/student.xls");
wb.write(fout);
fout.close();
}
}
效果:

注:.首先下载poi-3.6-20091214.jar,下载地址如下:
http://download.csdn.net/detail/evangel_z/3895051
2.使用JXL生成文件
package com.mi.util; import java.io.File; import jxl.Workbook;
import jxl.format.Border;
import jxl.format.BorderLineStyle;
import jxl.format.Colour;
import jxl.write.Label;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook; public class JxlExcelCreateTool { public static void main(String[] args) throws Exception {
writeExcel();
} public static void writeExcel() throws Exception {
// 第一步创建excel文件,并决定excel的路径和文件名
WritableWorkbook wwb = Workbook.createWorkbook(new File("D:/hello.xls")); // 第二部,创建工作簿,指定该工作簿的名称和位置'
WritableSheet sheet = wwb.createSheet("test sheet1", 0); // 第三部,设置表格指定列的列宽
sheet.setColumnView(0, 14);
sheet.setColumnView(1, 12);
sheet.setColumnView(2, 25);
sheet.setColumnView(3, 20);
sheet.setColumnView(4, 12);
sheet.setColumnView(5, 9); // 第四部,往工作簿中插入数据,设定字体:微软雅黑,24,加粗
// 创建字体对象
WritableFont titleFont = new WritableFont(WritableFont.createFont("微软雅黑"), 24, WritableFont.NO_BOLD);
WritableFont contentFont = new WritableFont(WritableFont.createFont("楷体 _GB2312"), 12, WritableFont.NO_BOLD);
WritableCellFormat titleFormat = new WritableCellFormat(titleFont);
WritableCellFormat contentFormat = new WritableCellFormat(contentFont);
WritableCellFormat contentFormat2 = new WritableCellFormat(contentFont); contentFormat.setBorder(Border.ALL, BorderLineStyle.THIN, Colour.BLACK);
// 设置格式居中对齐
titleFormat.setAlignment(jxl.format.Alignment.CENTRE);
contentFormat.setAlignment(jxl.format.Alignment.CENTRE);
contentFormat2.setAlignment(jxl.format.Alignment.CENTRE); // 将定义好的单元格绑定数据添加到工作簿中
sheet.mergeCells(0, 0, 6, 0); // 合并单元格A-G列共7列
sheet.addCell(new Label(0, 0, "广州XXX大学2009级研究生课程考试成绩册", titleFormat));
sheet.addCell(new Label(0, 1, "课程名称", contentFormat2));
sheet.mergeCells(1, 1, 6, 1); // 合并单元格B-G列共7列
sheet.addCell(new Label(1, 1, "大学数学", contentFormat2));
sheet.addCell(new Label(0, 2, "院所教研室", contentFormat2));
sheet.mergeCells(1, 2, 6, 2); // 合并单元格B-G列共7列
sheet.addCell(new Label(0, 3, "填表人", contentFormat2));
sheet.addCell(new Label(2, 3, "教研室负责人", contentFormat2)); String th[] = { "学号", "姓名", "学院", "平时成绩", "期末成绩", "总成绩", "补考成绩" };
for (int i = 0; i < th.length; i++) {
sheet.addCell(new Label(i, 4, th[i], contentFormat2));
}
// 这里的数据可以从数据库里获取,个人建议将这些抽成共通的方法,提供导入数据,用时调用即可
int xh = 200901;
String xm = "王佳佳";
String xy = "XXX信息技术学院";
String space = " ";
int cj = 50;
String bk = "补 80"; for (int j = 5; j < 10; j++) {
sheet.addCell(new Label(0, j, "" + xh + j + "", contentFormat));
sheet.addCell(new Label(1, j, xm + j, contentFormat));
sheet.addCell(new Label(2, j, xy, contentFormat));
sheet.addCell(new Label(3, j, space, contentFormat));
sheet.addCell(new Label(4, j, space, contentFormat));
sheet.addCell(new Label(5, j, "" + cj + j + "", contentFormat));
sheet.addCell(new Label(6, j, "" + bk + "", contentFormat));
} // 第五部,写入工作表完毕,关闭流
wwb.write();
wwb.close();
}
}
效果:

Java生成excel导出文件(使用poi+JXL)的更多相关文章
- java 生成Excel开门篇
本随笔的Excel所用的poi jar包(3.17版本)链接: https://pan.baidu.com/s/1gaa3dJueja8IraUDYCSLIQ 提取密码: 9xr7 简单实现:两个类: ...
- oracle PL/SQL调用Java生成Excel
现在有个需求, 要求编写oracle存储过程生成Excel文件到指定目录, 但是oracle自己的API貌似不太给力, 所以只能通过另一种更强大的语言来实现了 ——Java.有一个Java框架 ...
- JAVA生成EXCEL模板
JAVA生成excel模板,支持1.必填字段前加 红色 * 2.定义可选值下拉列表 valList3.定义名称并通过名称设置可选值 refName(名称在sheet2,sheet2自动隐藏)4.支持设 ...
- [转]java生成 excel 并导出文件
原文:https://blog.csdn.net/xunwei0303/article/details/53213130 目前,比较常用的实现Java导入.导出Excel的技术有两种Jakarta P ...
- Java操作Excel(使用POI)
背景说明 以前写过使用 JXL 操作Excel的例子,但JXL对于Excel 2007版本以后的文件(即扩展名为 .xlsx)无法读取,也找不到可以支持的包.所以,有时不得不用 POI 来操作Exce ...
- java生成excel
package test.poi; import java.io.File; import java.io.FileOutputStream; import java.io.OutputStream; ...
- java生成excel报表文件
此次简单的操作将数据从数据库导出生成excel报表以及将excel数据导入数据库 首先建立数据库的连接池: package jdbc; import java.io.FileInputStream; ...
- 两种方式实现java生成Excel
Web应用中难免会遇到需要将数据导出并生成excel文件的需求.同样,对于本博客中的总结,也是建立在为了完成这样的一个需求,才开始去了解其实现形式,并且顺利完成需求的开发,先将实现过程总结于此.本博文 ...
- JAVA实现Excel的读写--poi
上一篇为大家介绍了通过xls.jar的方式生成Excel的方法,本篇就为大家再介绍一下通过poi方式实现Excel文件的读写操作,内容很简单,代码注释很清晰. 1.生成Excel文件: import ...
随机推荐
- jquery在线手册
开发时用到jquery,有几个函数想不起来怎么用,找了一下jquery在线手册. 记录一下,下回有需要再看看. 链接:http://www.chenfahui.cn/jq/
- JS通用事件监听函数
JS通用事件监听函数 版本一 //把它全部封装到一个对象中 var obj={ readyEvent:function (fn){ if(fn==null){ fn=document; } var o ...
- rem适配
//REM适配new function() { var _self = this; _self.width = 640; // 设置默认最大宽度 _self.fontSize = 100; // 默认 ...
- Fiddler学习纪要
一.Fiddler支持功能 1.查看几乎所有的浏览器.客户端应用或服务器之间的WEB数据流 2.手动或自动修改任意的请求或响应 3.解密HTTPS数据流以便查看或修改 4.归档捕获到的数据流,支持再不 ...
- ucenter 显示通信成功的条件
应用的主 URL+/api/uc.php?code= 如果这个页面返回1,则通信成功,也就是说,uc.php是通信成功里重要的一环 事实上,我还没有通信成功,我只是写了一个1在欺骗服务端
- SQL Server Transaction Log Truncate && Shrink
目录 什么是事务日志 事务日志的组成 事务日志大小维护方法 Truncate Shrink 索引碎片 总结 什么是事务日志 Transaction log 是对数据库管理系统执行的一系列动作的记录 ...
- Java 多线程Future和FutureTask
Future表示一个任务的周期,并提供了相应的方法来判断是否已经完成或者取消,以及获取任务的结果和取消任务. Future接口源码: public interface Future<V> ...
- 第七篇 Integration Services:中级工作流管理
本篇文章是Integration Services系列的第七篇,详细内容请参考原文. 简介在上一篇文章,我们创建了一个新的SSIS包,学习了SSIS中的脚本任务和优先约束,并检查包的MaxConcur ...
- RouteOS软路由HotSpot热点认证网关添加白名单和黑名单
1.添加白名单和黑名单地址池 白名单IP地址池 172.18.10.0/24 黑名单IP地址池 172.18.20.0/24 2.添加IP网关 白名单网关 172.18.10.0/24 黑名单网关 1 ...
- Vue.2.0.5-过渡状态
过渡状态 Vue 的过渡系统提供了非常多简单的方法设置进入.离开和列表的动效.那么对于数据元素本身的动效呢,比如: 数字和运算 颜色的显示 SVG 节点的位置 元素的大小和其他的属性 所有的原始数字都 ...