网站首页 > java教程 正文
在实际中导出excel非常常见,于是自己封装了一个导出数据到excel的工具类,先附上代码,最后会写出实例和解释。
代码中依赖了slf4j日志包,commons-io包的IOUtils关闭流,commons-lang和commons-collections包等包。

package cn.xm.exam.utils;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.apache.commons.collections.MapUtils;
import org.apache.commons.io.IOUtils;
import org.apache.commons.lang.ArrayUtils;
import org.apache.commons.lang3.StringUtils;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class HSSFWorkExcel {
private static final Logger LOGGER = LoggerFactory.getLogger(HSSFWorkExcel.class);
private String[] headerNames;
private HSSFWorkbook workBook;
private HSSFSheet sheet;
public HSSFWorkExcel(String[] headerNames, String sheetName) {
this.headerNames = headerNames;
// 创建一个工作簿
workBook = new HSSFWorkbook();
// 创建一个工作表sheet
sheet = workBook.createSheet(sheetName);
initHeader();
}
/**
* 初始化表头信息
*/
private void initHeader() {
// 创建第一行
HSSFRow row = sheet.createRow(0);
HSSFCell cell = null;
// 创建表头
for (int i = 0; i < headerNames.length; i++) {
cell = row.createCell(i);
cell.setCellValue(headerNames[i]);
setCellStyle(cell);
}
}
/**
* 设置单元格样式
*
* @param cell
* 单元格
*/
public void setCellStyle(HSSFCell cell) {
// 设置样式
HSSFCellStyle cellStyle = workBook.createCellStyle();
cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 设置字体居中
// 设置字体
HSSFFont font = workBook.createFont();
font.setFontName("宋体");
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);// 字体加粗
font.setFontHeightInPoints((short) 13);
cellStyle.setFont(font);
cell.setCellStyle(cellStyle);
}
/**
* 创建行内容(每一行的数据装在list中)
*
* @param datas
* 每一行的数据
* @param rowIndex
* 行号(从1开始)
*/
public void createTableRow(List<String> datas, int rowIndex) {
// 创建第i行
HSSFRow row = sheet.createRow(rowIndex);
HSSFCell cell = null;
// 写入数据
for (int index = 0, length = datas.size(); index < length; index++) {
// 参数代表第几列
cell = row.createCell(index);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue(datas.get(index));
}
}
/**
*
* @param datas
* 数据,每一个map都是一行
* @param keys
* key[i]代表从map中获取keys[i]的值作为第i列的值,如果传的是null默认取表头
*/
public void createTableRows(List<Map<String, Object>> datas, String[] keys) {
for (int i = 0, length_1 = datas.size(); i < length_1; i++) {
if (ArrayUtils.isEmpty(keys)) {
keys = headerNames;
}
// 创建行(从第二行开始)
Map<String, Object> data = datas.get(i);
HSSFRow row = sheet.createRow(i + 1);
HSSFCell cell = null;
for (int j = 0, length_2 = keys.length; j < length_2; j++) {
// 单元格获取map中的key
String key = keys[j];
String value = MapUtils.getString(data, key, "");
cell = row.createCell(j);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue(value);
}
}
}
/**
* 根据表头自动调整列宽度
*/
public void autoAllSizeColumn() {
for (int i = 0, length = headerNames.length; i < length; i++) {
sheet.autoSizeColumn(i);
}
}
/**
* 将数据写出到excel中
*
* @param outputStream
*/
public void exportExcel(OutputStream outputStream) {
// 导出之前先自动设置列宽
this.autoAllSizeColumn();
try {
workBook.write(outputStream);
} catch (IOException e) {
LOGGER.error(" exportExcel error", e);
} finally {
IOUtils.closeQuietly(outputStream);
}
}
}
上面的代码逻辑非常简单,创建实例的时候就初始化表头信息和创建sheet。
向excel中填充数据的方式有两种,就是上面的createTableRow方法和createTableRows方法。
createTableRow(List,int)方法就是多次调用此方法,list中数据,int是行号。list中数据依次作为第i行的列数据。
createTableRows(List<Map>,String[])这个方法应该是非常常用的一种方式。我们从数据库查询到的数据大多数映射为Map放入list中,因此上面的方法就比较常用。List<Map>参数就是所有的数据,一个Map代表一行,String[]是Map中的key,也就是数组的第一个元素对应的key作为第一列,第二个元素是作为第二列。如果map数据的key正好与表头一致我们可以传一个null。(因为Map是基于数组+链表,且存入的是无序的,所以无法直接通过map中的key确定列。除非传的数据是LinkedHashMap)
下面是自己的两个测试代码:
(1)测试List<String>写入数据
public static void test1() {
HSSFWorkExcel hssfWorkExcel = new HSSFWorkExcel(new String[] { "姓名", "年龄" }, "人员基本信息");
for (int i = 0; i < 10; i++) {
List<String> data = new ArrayList<>();
data.add("namesssssssssssssss水水水水水水水水水水水水水水水水水水水ssssssssssssssss" + i);
data.add("" + (i + 20));
hssfWorkExcel.createTableRow(data, i + 1);
}
try {
hssfWorkExcel.exportExcel(new FileOutputStream(new File("e:/test.xls")));
} catch (FileNotFoundException e) {
e.printStackTrace();
}
}
结果:
(2)测试List<Map>写入数据
public static void test2() {
HSSFWorkExcel hssfWorkExcel = new HSSFWorkExcel(new String[] { "姓名", "年龄" }, "人员基本信息");
List<Map<String, Object>> datas = new ArrayList<>();
for (int i = 0; i < 10; i++) {
Map data = new HashMap<>();
data.put("name", "tttttttttttttt" + i);
data.put("age", "age" + i);
datas.add(data);
}
hssfWorkExcel.createTableRows(datas, new String[] { "name", "age" });
try {
hssfWorkExcel.exportExcel(new FileOutputStream(new File("e:/test1.xls")));
} catch (FileNotFoundException e) {
e.printStackTrace();
}
}
结果:
猜你喜欢
- 2024-09-21 如何把excel表格处理成json数据(jason转excel)
- 2024-09-21 一个读Excel数据的小例子,提供给爱学习的Java后端开发
- 2024-09-21 快速将Excel、CSV等格式文件数据转换到java对象
- 2024-09-21 GitHub Star 8800+ 的阿里开源的 Java 解析 Excel 工具
- 2024-09-21 还在重复劳动?不如用Python自动生成Excel以邮件发送
- 2024-09-21 Java8如何让Excel的读写变得更加简单高效
- 2024-09-21 java打印Excel表格(java输出excel表格)
- 2024-09-21 整理关于java写入内容到excel的例子供大家参考
- 2024-09-21 JavaAPI开发(3)POI——如何将List转换为excel文件
- 2024-09-21 【Java程序】读取指定路径下文件夹中的文件名,生成Excel表格!
欢迎 你 发表评论:
- 12-03photoshop cs6 序列号(photoshopcs6序列号)
- 12-03上海联想笔记本售后维修服务网点
- 12-02应用软件app(应用软件APP排行榜前十名)
- 12-02win11有必要经常更新系统吗(win11值不值得更新)
- 12-02u盘在电脑上读不出来是什么原因
- 12-02家庭路由器哪种比较好用(家庭路由器哪种比较好用2020年)
- 12-02怎样装电脑台式机(如何组装电脑台式机)
- 12-02u盘格式化后识别不出来怎么办
- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)

本文暂时没有评论,来添加一个吧(●'◡'●)