Java操作Excel文件的写入(文件中含有多张工作表)
在本人工作的过程中,遇到了形形色色的问题。当时琢磨了好久才琢磨出这样的总结,贴出来供大家参考参考。以下观点仅代表本人在工作过程中的观点,望大家能够共同讨论,查漏补缺。
由于工作需要,最近公司需要我来通过从数据库中导出表中的数据,然后将数据导出成Excel表格的性格。由于需要作出不同统计的操作,但是却要求导出成一个Excel文档,而不是多个文档。而在网上形形色色的资料中,似乎还没有找到一个Excel文档中导出多张工作表。因此,将我自己写的贴出来让大家参考参考。
首先我们来明确一下需求(表名以及表结构为虚构,大家需要针对自己的需求进行修改):
1、导出Employee表中的数据,其中Employee表中的数据格式为:
Long id
String username;
int sex
int age
String height
String weight
String ts (入职时间)
2、在一个Excel文档中需要统计出两种数据。一种为全部Employee的数据。一种为入职时间在本周的数据
所谓代码未动,jar包先行。我们首先需要的就是导入我们的jar包。
传送门:
注意:在这里我只提供apache的poi包,就是用于Java操作Excel的所需包,而不提供连接数据库的jar包。因此切勿忘记导入jar包时操作数据库需要导入相关的jar包
那么导入了jar包之后,我们就可以开始写我们的代码了!
首先我们需要定义一个UserinfoData类,用于封装查询到的数据
public class UserinfoData {
private String email;
private int sex;
private String age;
private String height;
private String weight;
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public int getSex() {
return sex;
}
public void setSex(int sex) {
this.sex = sex;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
public String getHeight() {
return height;
}
public void setHeight(String height) {
this.height = height;
}
public String getWeight() {
return weight;
}
public void setWeight(String weight) {
this.weight = weight;
}
}
这里可能就会有人疑惑了,Student表中不是有一个ts字段吗,怎么定义的UserinfoData中没有ts呢?
其实很简单啊,因为这样简单的操作不需要使用到框架那么高大上复杂的东西,使用简单的jdbc就行了,因此不必字段跟表中列相对应的。
创建好了封装对象之后,我们就需要通过查询数据库获取到相应的数据了。
import java.sql.DriverManager;
import java.util.ArrayList;
import java.util.List;
import org.junit.Test;
import com.mysql.jdbc.Connection;
import com.mysql.jdbc.PreparedStatement;
import com.mysql.jdbc.ResultSet;
/**
* 导出数据库中的数据到Excel中
* @author 昆仑山神
*
*/
public class ExportExcelTest_poi {
@Test
public void testExcelExport() throws Exception {
String DRIVER = "com.mysql.jdbc.Driver";
String URL = "jdbc:mysql:///test?useUnicode=true&characterEncoding=UTF-8";
String USERNAME = "xxxx";
String USERPASSWORD = "xxxx";
List<String> oneWeek = DateUtil.getOneWeek();// 获取一周时间
String sqlAll = "SELECT * FROM t_userinfo"; // 查询总用户数据
String sqlWeek = "SELECT * FROM t_userinfo WHERE ts BETWEEN '"+oneWeek.get(0)+"' AND '"+oneWeek.get(6)+ "'"; // 查询本周新增用户数据
// 连接数据库
Class.forName(DRIVER);
//声明对象
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
PreparedStatement psWeek = null;
ResultSet rsWeek = null;
try {
conn = (Connection) DriverManager.getConnection(URL,USERNAME,USERPASSWORD);
ps = (PreparedStatement) conn.prepareStatement(sqlAll);
rs = (ResultSet) ps.executeQuery();
List<UserinfoData> userinfoDataList = new ArrayList<UserinfoData>();
while(rs.next()){
UserinfoData userinfoData = new UserinfoData();
userinfoData.setEmail(rs.getString("username"));
userinfoData.setSex(rs.getInt("sexCode"));
userinfoData.setAge(rs.getString("birthday"));
userinfoData.setHeight(rs.getString("height"));
userinfoData.setWeight(rs.getString("weight"));
userinfoDataList.add(userinfoData);
}
System.out.println(userinfoDataList.size());
psWeek = (PreparedStatement) conn.prepareStatement(sqlWeek);
rsWeek = (ResultSet) psWeek.executeQuery();
List<UserinfoData> userinfoDataListWeek = new ArrayList<UserinfoData>();
while(rsWeek.next()){
UserinfoData userinfoData = new UserinfoData();
userinfoData.setEmail(rsWeek.getString("username"));
userinfoData.setSex(rsWeek.getInt("sexCode"));
userinfoData.setAge(rsWeek.getString("birthday"));
userinfoData.setHeight(rsWeek.getString("height"));
userinfoData.setWeight(rsWeek.getString("weight"));
userinfoDataListWeek.add(userinfoData);
}
System.out.println(userinfoDataListWeek.size());
// 导出文件
CreateExcelUtil.createExcel(userinfoDataList, userinfoDataListWeek);
} catch (Exception e) {
e.printStackTrace();
}finally{
//关闭连接
try {
if(rs != null){
rs.close();
}
} catch (Exception e2) {
e2.printStackTrace();
}finally{
try {
if(ps != null){
ps.close();
}
} catch (Exception e3) {
e3.printStackTrace();
}finally{
try {
if(conn != null){
conn.close();
}
} catch (Exception e4) {
e4.printStackTrace();
}
}
}
}
}
}
因为我们需要获取到本周的数据,因此需要对时间进行解析,因此我们额外的写了一个工具类。
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.List;
public class DateUtil {
private static final int FIRST_DAY = Calendar.MONDAY;
public static List<String> getOneWeek(){
List<String> weekList = new ArrayList<String>();
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Calendar calendar = Calendar.getInstance();
setToFirstDay(calendar);
for (int i = 0; i < 7; i++) {
if(i == 0){
calendar.set(Calendar.HOUR_OF_DAY, 0);
calendar.set(Calendar.MINUTE, 0);
calendar.set(Calendar.SECOND, 0);
}else if(i == 6){
calendar.set(Calendar.HOUR_OF_DAY, 23);
calendar.set(Calendar.MINUTE, 59);
calendar.set(Calendar.SECOND, 59);
}
weekList.add(dateFormat.format(calendar.getTime()));
calendar.add(Calendar.DATE, 1);
}
return weekList;
}
private static void setToFirstDay(Calendar calendar) {
while (calendar.get(Calendar.DAY_OF_WEEK) != FIRST_DAY) {
calendar.add(Calendar.DATE, -1);
}
}
}
最后的重头戏就是我们的生成文件的程序了:
import java.io.FileOutputStream;
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;
/**
* 导出数据库中的数据到Excel中
* @author 昆仑山神
*
*/
@SuppressWarnings("deprecation")
public class CreateSimpleExcelToDisk
{
public static boolean createExcel(List<UserinfoData> userinfoDataListAll, List<UserinfoData> userinfoDataListWeek) throws Exception{
try {
if(userinfoDataListAll != null && userinfoDataListAll.size() > 0){
// 创建一个webbook,对应一个Excel文件
HSSFWorkbook wb = new HSSFWorkbook();
// 在webbook中添加多个sheet,对应Excel文件中的sheet
HSSFSheet sheetAll = wb.createSheet("总用户表");
// 设置格式,设置表头居中
HSSFCellStyle style = wb.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 创建一个居中格式
// 在sheet中添加表头第0行,显示总用户数
HSSFRow rowAllHead = sheetAll.createRow((int) 0);
HSSFCell cellAllHead = rowAllHead.createCell((short) 0);
cellAllHead.setCellValue("总用户数: " + userinfoDataListAll.size());
cellAllHead.setCellStyle(style);
//总用户表
HSSFRow rowAll = sheetAll.createRow((int) 1);
HSSFCell cellAll = rowAll.createCell((short) 0);
//设置列名以及格式(与传入的List集合中的对象的字段相一致)
cellAll.setCellValue("邮箱");
cellAll.setCellStyle(style);
cellAll = rowAll.createCell((short) 1);
cellAll.setCellValue("性别");
cellAll.setCellStyle(style);
cellAll = rowAll.createCell((short) 2);
cellAll.setCellValue("年龄");
cellAll.setCellStyle(style);
cellAll = rowAll.createCell((short) 3);
cellAll.setCellValue("身高");
cellAll.setCellStyle(style);
cellAll = rowAll.createCell((short) 4);
cellAll.setCellValue("体重");
cellAll.setCellStyle(style);
// 写入实体数据
for (int i = 0; i < userinfoDataListAll.size(); i++)
{
rowAll = sheetAll.createRow((int) i + 2);
UserinfoData ud = (UserinfoData) userinfoDataListAll.get(i);
// 创建单元格,并设置值
rowAll.createCell((short) 0).setCellValue(ud.getEmail());
rowAll.createCell((short) 1).setCellValue(ud.getSex() == 1 ? "男" : "女");
rowAll.createCell((short) 2).setCellValue(ud.getAge());
rowAll.createCell((short) 3).setCellValue(ud.getHeight());
rowAll.createCell((short) 4).setCellValue(ud.getWeight());
}
//自动调整总用户表列宽
sheetAll.autoSizeColumn((short)0);
sheetAll.autoSizeColumn((short)1);
sheetAll.autoSizeColumn((short)2);
sheetAll.autoSizeColumn((short)3);
sheetAll.autoSizeColumn((short)4);
//本周新增用户表
HSSFSheet sheetWeek = wb.createSheet("本周新增用户表");
// 在sheet中添加表头第0行,显示本周增加用户数
HSSFRow rowWeekHead = sheetWeek.createRow((int) 0);
HSSFCell cellWeekHead = rowWeekHead.createCell((short) 0);
cellWeekHead.setCellValue("本周新增用户数: " + userinfoDataListWeek.size());
cellWeekHead.setCellStyle(style);
HSSFRow rowWeek = sheetWeek.createRow((int) 1);
HSSFCell cellWeek = rowWeek.createCell((short) 0);
//设置列名以及格式(与传入的List集合中的对象的字段相一致)
cellWeek.setCellValue("邮箱");
cellWeek.setCellStyle(style);
cellWeek = rowWeek.createCell((short) 1);
cellWeek.setCellValue("性别");
cellWeek.setCellStyle(style);
cellWeek = rowWeek.createCell((short) 2);
cellWeek.setCellValue("年龄");
cellWeek.setCellStyle(style);
cellWeek = rowWeek.createCell((short) 3);
cellWeek.setCellValue("身高");
cellWeek.setCellStyle(style);
cellWeek = rowWeek.createCell((short) 4);
cellWeek.setCellValue("体重");
cellWeek.setCellStyle(style);
if(userinfoDataListWeek != null && userinfoDataListWeek.size() > 0){
// 写入实体数据
for (int i = 0; i < userinfoDataListWeek.size(); i++)
{
rowWeek = sheetWeek.createRow((int) i + 2);
UserinfoData ud = (UserinfoData) userinfoDataListWeek.get(i);
// 创建单元格,并设置值
rowWeek.createCell((short) 0).setCellValue(ud.getEmail());
rowWeek.createCell((short) 1).setCellValue(ud.getSex() == 1 ? "男" : "女");
rowWeek.createCell((short) 2).setCellValue(ud.getAge());
rowWeek.createCell((short) 3).setCellValue(ud.getHeight());
rowWeek.createCell((short) 4).setCellValue(ud.getWeight());
}
}
//自动调整本周新增用户表列宽
sheetWeek.autoSizeColumn((short)0);
sheetWeek.autoSizeColumn((short)1);
sheetWeek.autoSizeColumn((short)2);
sheetWeek.autoSizeColumn((short)3);
sheetWeek.autoSizeColumn((short)4);
// 将文件存到指定位置
FileOutputStream fout = new FileOutputStream("E:/test.xls");
wb.write(fout);
fout.close();
return true;
}else{
return false;
}
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
}
这样,我们就能够导出相关的数据出来啦!!导出来的文件大致样子是这样滴!