首先,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
要用到的类
最最基本的使用
//创建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
相关文章:
香港服务器WordPress建站指南:SEO优化与高效部署策略
如何在建站宝盒中设置产品搜索功能?
如何在服务器上三步完成建站并提升流量?
简单实现Android验证码
如何在建站之星网店版论坛获取技术支持?
建站主机选购指南:核心配置优化与品牌推荐方案
营销式网站制作方案,销售哪个网站招聘效果最好?
如何基于云服务器快速搭建网站及云盘系统?
如何打造高效商业网站?建站目的决定转化率
,交易猫的商品怎么发布到网站上去?
定制建站是什么?如何实现个性化需求?
购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?
如何选择美橙互联多站合一建站方案?
如何在阿里云部署织梦网站?
佛山网站制作系统,佛山企业变更地址网上办理步骤?
如何配置支付宝与微信支付功能?
如何在香港免费服务器上快速搭建网站?
如何通过VPS建站实现广告与增值服务盈利?
如何用AWS免费套餐快速搭建高效网站?
保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?
深圳网站制作培训,深圳哪些招聘网站比较好?
如何选择网络建站服务器?高效建站必看指南
已有域名如何免费搭建网站?
如何选择高效便捷的WAP商城建站系统?
如何选择最佳自助建站系统?快速指南解析优劣
国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?
C++时间戳转换成日期时间的步骤和示例代码
广州网站建站公司选择指南:建站流程与SEO优化关键词解析
如何快速完成中国万网建站详细流程?
如何获取开源自助建站系统免费下载链接?
如何获取上海专业网站定制建站电话?
已有域名能否直接搭建网站?
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
如何用VPS主机快速搭建个人网站?
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
如何在Tomcat中配置并部署网站项目?
北京制作网站的公司,北京铁路集团官方网站?
,巨量百应是干嘛的?
小自动建站系统:AI智能生成+拖拽模板,多端适配一键搭建
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
Python lxml的etree和ElementTree有什么区别
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
杭州银行网站设计制作流程,杭州银行怎么开通认证方式?
如何在万网ECS上快速搭建专属网站?
实现点击下箭头变上箭头来回切换的两种方法【推荐】
做企业网站制作流程,企业网站制作基本流程有哪些?
如何用IIS7快速搭建并优化网站站点?
建站之星CMS建站配置指南:模板选择与SEO优化技巧
如何基于云服务器快速搭建个人网站?
音响网站制作视频教程,隆霸音响官方网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。