Java通过apache poi生成excel实例代码

发布时间 - 2026-01-11 01:42:45    点击率:

首先,jar

maven 添加依赖

<!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml -->
<dependency>
 <groupId>org.apache.poi</groupId>
 <artifactId>poi-ooxml</artifactId>
 <version>3.15</version>
</dependency>

开始以为是poi,然后就直接加poi的依赖,谁知道并没有所需要的类。查了查才发现是poi-ooxml

要用到的类

  1. XSSFWorkbook , 代表一个excel文档
  2. XSSFSheet , 代表文档中的一个sheet
  3. XSSFRow , 代表sheet中的一行
  4. XSSFCell , 代表row中的每一项的值

最最基本的使用

//创建excel文档
XSSFWorkbook workbook = new XSSFWorkbook();
//创建sheet
XSSFSheet sheet = workbook.createSheet("sheetName");

int rownum=0;
//创建首行
XSSFRow firstrow = sheet.createRow(rownum++);
int cellnum = 0;
//把保存在titles中的各个列名,分别在row中创建cell
for(String key : titles){
 XSSFCell cell = firstrow.createCell(cellnum++);
 cell.setCellValue(key);
}


//下面可以继续创建行

//把excel写到要写的outputStream中
workbook.write(output);
//最后关闭
workbook.close();

小例子一枚

利用反射,把bean类中各属性(用getXxx取出),写入到excel中

ExcelUtil.java

package me.paul.excelDemo;

import java.io.IOException;
import java.io.OutputStream;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;


public class ExcelUtil {
 
 public <T> void getExcel(List<T> list,Class<T> c,OutputStream output) throws IOException, IllegalAccessException, IllegalArgumentException, InvocationTargetException{
 Map<String,Method> methodMap = new LinkedHashMap<>(); 
 Method[] methods = c.getDeclaredMethods();
 for(int i=0;i<methods.length;i++){
  Method method = methods[i];
  String name = method.getName();
  Pattern pattern = Pattern.compile("get(.*)");
  Matcher matcher = null;
  if((matcher = pattern.matcher(name)).matches()){
  name = matcher.group(1);
  char ch = name.charAt(0);
  char newch = (char) (ch + 32); 
  name = name.replace(ch,newch);
  methodMap.put(name, method);
  }
 }
 
 XSSFWorkbook workbook = new XSSFWorkbook();
 XSSFSheet sheet = workbook.createSheet(c.getCanonicalName());
 int rownum=0;
 XSSFRow firstrow = sheet.createRow(rownum++);
 int cellnum = 0;
 for(String key : methodMap.keySet()){
  XSSFCell cell = firstrow.createCell(cellnum++);
  cell.setCellValue(key);
 }
 
 for(T t : list){
  XSSFRow row = sheet.createRow(rownum++);
  cellnum = 0;
  for(String key:methodMap.keySet()){
  Method method = methodMap.get(key);
                //设置可访问,之前不知道这方法,所以关于反射那篇文章有错误,见谅见谅
                method.setAccessible(true);
  Object obj = method.invoke(t);
  XSSFCell cell = row.createCell(cellnum++);
  cell.setCellValue(obj== null ? "":obj.toString());
  }
  
 }
 workbook.write(output);
 workbook.close();
 } 
}

App.java 进行测试使用

package me.paul.excelDemo;

import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.lang.reflect.InvocationTargetException;
import java.util.ArrayList;
import java.util.List;

public class App {
 public static void main(String[] args) throws IllegalAccessException, IllegalArgumentException, InvocationTargetException, IOException {
 List<User> list = new ArrayList<>();
 User u = new User();
 u.setId(1);
 u.setName("Paul");
 u.setAge(18);
 list.add(u);
 u = new User();
 u.setId(2);
 u.setName("Johnson");
 u.setAge(20);
 list.add(u);
 u = new User();
 u.setId(3);
 u.setName("David");
 u.setAge(22);
 list.add(u);
 OutputStream output = new FileOutputStream("/home/paul/user.xlsx");
 new ExcelUtil().getExcel(list, User.class,output);
 output.close();
 }
}

测试结果截图

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# apache  # poi  # 读取excel  # excel  # poi生成excel文件  # Java使用Apache POI操作Excel详解  # Java使用apache poi操作excel的方式  # Java使用Apache.POI中HSSFWorkbook导出到Excel的实现方法  # java后台利用Apache poi 生成excel文档提供前台下载示例  # Java使用Apache POI库读取Excel表格文档的示例  # 使用 Apache POI 在 Java 中写入&  # 文档  # 才发现  # 要用  # 谁知道  # 写到  # 一枚  # 所需要  # 大家多多  # 要写  # 有错误  # 进行测试  # 每一项  # 那篇  # 类中  # 然后就  # 分别在  # sheetName  # cell  # createSheet  # int 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  如何用低价快速搭建高质量网站?  Laravel如何实现URL美化Slug功能_Laravel使用eloquent-sluggable生成别名【方法】  Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】  php打包exe后无法访问网络共享_共享权限设置方法【教程】  Laravel N+1查询问题如何解决_Eloquent预加载(Eager Loading)优化数据库查询  Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  Swift开发中switch语句值绑定模式  如何用PHP工具快速搭建高效网站?  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  夸克浏览器网页跳转延迟怎么办 夸克浏览器跳转优化  大连 网站制作,大连天途有线官网?  Laravel如何生成URL和重定向?(路由助手函数)  如何快速查询网址的建站时间与历史轨迹?  油猴 教程,油猴搜脚本为什么会网页无法显示?  Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势  Android仿QQ列表左滑删除操作  如何使用 jQuery 正确渲染 Instagram 风格的标签列表  标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  简历没回改:利用AI润色让你的文字更专业  如何在 Pandas 中基于一列条件计算另一列的分组均值  Laravel如何优化应用性能?(缓存和优化命令)  Laravel Octane如何提升性能_使用Laravel Octane加速你的应用  七夕网站制作视频,七夕大促活动怎么报名?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  如何快速搭建虚拟主机网站?新手必看指南  移动端脚本框架Hammer.js  Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区  如何快速搭建安全的FTP站点?  javascript中的try catch异常捕获机制用法分析  如何登录建站主机?访问步骤全解析  如何彻底删除建站之星生成的Banner?  Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】  Laravel如何实现API版本控制_Laravel API版本化路由设计策略  如何在IIS服务器上快速部署高效网站?  香港服务器网站推广:SEO优化与外贸独立站搭建策略  Laravel Livewire是什么_使用Laravel Livewire构建动态前端界面  Laravel怎么实现验证码(Captcha)功能  如何用已有域名快速搭建网站?  googleplay官方入口在哪里_Google Play官方商店快速入口指南  微信小程序 HTTPS报错整理常见问题及解决方案  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  如何自定义建站之星模板颜色并下载新样式?  html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】  PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)  EditPlus中的正则表达式 实战(1)  微信小程序 require机制详解及实例代码  如何快速辨别茅台真假?关键步骤解析