java利用注解实现简单的excel数据读取
发布时间 - 2026-01-11 02:07:05 点击率:次实现工具类

利用注解实现简单的excel数据读取,利用注解对类的属性和excel中的表头映射,使用Apache的poi就不用在业务代码中涉及row,rows这些属性了。
定义注解:
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface Excel {
String name();
}
由于本例中只涉及根据Excel表头部分对Excel进行解析,只定义了一个name作为和Excel表头的隐射。
工具类完整代码如下:
public class ExcelUtil<T> {
Class<T> clazz;
public ExcelUtil(Class<T> clazz) {
this.clazz = clazz;
}
public List<T> importExcel(String sheetName, InputStream input) {
int maxCol = 0;
List<T> list = new ArrayList<T>();
try {
Workbook workbook = WorkbookFactory.create(input);
Sheet sheet = workbook.getSheet(sheetName);
// 如果指定sheet名,则取指定sheet中的内容.
if (!sheetName.trim().equals("")) {
sheet = workbook.getSheet(sheetName);
}
// 如果传入的sheet名不存在则默认指向第1个sheet.
if (sheet == null) {
sheet = workbook.getSheetAt(0);
}
int rows = sheet.getPhysicalNumberOfRows();
// 有数据时才处理
if (rows > 0) {
List<Field> allFields = getMappedFiled(clazz, null);
// 定义一个map用于存放列的序号和field.
Map<Integer, Field> fieldsMap = new HashMap<Integer, Field>();
// 第一行为表头
Row rowHead = sheet.getRow(0);
Map<String, Integer> cellMap = new HashMap<>();
int cellNum = rowHead.getPhysicalNumberOfCells();
for (int i = 0; i < cellNum; i++){
cellMap.put(rowHead.getCell(i).getStringCellValue().toLowerCase(), i);
}
for (Field field : allFields) {
// 将有注解的field存放到map中.
if (field.isAnnotationPresent(Excel.class)) {
Excel attr = field.getAnnotation(Excel.class);
// 根据Name来获取相应的failed
int col = cellMap.get(attr.name().toLowerCase());
field.setAccessible(true);
fieldsMap.put(col, field);
}
}
// 从第2行开始取数据
for (int i = 1; i < rows; i++) {
Row row = sheet.getRow(i);
T entity = null;
for (int j = 0; j < cellNum; j++) {
Cell cell = row.getCell(j);
if (cell == null) {
continue;
}
int cellType = cell.getCellType();
String c = "";
if (cellType == HSSFCell.CELL_TYPE_NUMERIC) {
DecimalFormat df = new DecimalFormat("0");
c = df.format(cell.getNumericCellValue());
} else if (cellType == HSSFCell.CELL_TYPE_BOOLEAN) {
c = String.valueOf(cell.getBooleanCellValue());
} else {
c = cell.getStringCellValue();
}
if (c == null || c.equals("")) {
continue;
}
entity = (entity == null ? clazz.newInstance() : entity);
// 从map中得到对应列的field.
Field field = fieldsMap.get(j);
if (field == null) {
continue;
}
// 取得类型,并根据对象类型设置值.
Class<?> fieldType = field.getType();
if (String.class == fieldType) {
field.set(entity, String.valueOf(c));
} else if ((Integer.TYPE == fieldType)
|| (Integer.class == fieldType)) {
field.set(entity, Integer.valueOf(c));
} else if ((Long.TYPE == fieldType)
|| (Long.class == fieldType)) {
field.set(entity, Long.valueOf(c));
} else if ((Float.TYPE == fieldType)
|| (Float.class == fieldType)) {
field.set(entity, Float.valueOf(c));
} else if ((Short.TYPE == fieldType)
|| (Short.class == fieldType)) {
field.set(entity, Short.valueOf(c));
} else if ((Double.TYPE == fieldType)
|| (Double.class == fieldType)) {
field.set(entity, Double.valueOf(c));
} else if (Character.TYPE == fieldType) {
if (c.length() > 0) {
field.set(entity, c.charAt(0));
}
}
}
if (entity != null) {
list.add(entity);
}
}
}
} catch (Exception e) {
e.printStackTrace();
}
return list;
}
/**
* 得到实体类所有通过注解映射了数据表的字段
*
* @param clazz
* @param fields
* @return
*/
private List<Field> getMappedFiled(Class clazz, List<Field> fields) {
if (fields == null) {
fields = new ArrayList<Field>();
}
// 得到所有定义字段
Field[] allFields = clazz.getDeclaredFields();
// 得到所有field并存放到一个list中.
for (Field field : allFields) {
if (field.isAnnotationPresent(Excel.class)) {
fields.add(field);
}
}
if (clazz.getSuperclass() != null
&& !clazz.getSuperclass().equals(Object.class)) {
getMappedFiled(clazz.getSuperclass(), fields);
}
return fields;
}
}
代码很简单,获取sheet,解析第一行,并和实体类标有注解的字段一一对应,用hashMap记录下来,然后循环取得Excel中剩下所有的数据,根据map的对应关系将值set到对应字段。
基本使用
待解析表格如下:
定义实体类:
public class User {
@Excel(name = "filed1")
private String name;
@Excel(name = "filed2")
private String nameEn;
@Excel(name = "filed3")
private Integer age;
@Excel(name = "filed4")
private String six;
@Excel(name = "filed5")
private String weight;
// ...getter setter
}
使用工具类:
public static void main (String[] args) {
FileInputStream fileInputStream = null;
try {
fileInputStream = new FileInputStream("D://data.xlsx");
} catch (FileNotFoundException e) {
e.printStackTrace();
}
ExcelUtil<User> util = new ExcelUtil<>(User.class);
List<User> jalanHotelList = util.importExcel("user", fileInputStream);
// do something
}
利用这个思路可以扩展出导出excel功能,利用注解指定导出的excel表头,甚至可以轻松控制excel表头的颜色,合并属性等等,在xdemo中有详细复杂的示例,可以研究下。由于我的需求很简单,就不整那么复杂啦。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# java
# 注解
# excel
# Java注解简单使用实例解析
# Java注解处理器简单实例
# Java利用自定义注解、反射实现简单BaseDao实例
# 简单谈谈java自定义注解
# Java注解的简单入门小案例
# 很简单
# 实体类
# 就不
# 中有
# 不存在
# 将有
# 用在
# 时才
# 大家多多
# 不整
# 标有
# 本例
# allFields
# null
# Field
# getPhysicalNumberOfRows
# getSheetAt
# create
# Sheet
# workbook
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
Java解压缩zip - 解压缩多个文件或文件夹实例
linux写shell需要注意的问题(必看)
今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】
Linux安全能力提升路径_长期防护思维说明【指导】
怎么用AI帮你为初创公司进行市场定位分析?
Laravel Session怎么存储_Laravel Session驱动配置详解
Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】
Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】
Laravel模型事件有哪些_Laravel Model Event生命周期详解
如何快速搭建虚拟主机网站?新手必看指南
C语言设计一个闪闪的圣诞树
laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法
使用spring连接及操作mongodb3.0实例
Laravel如何创建自定义Facades?(详细步骤)
python中快速进行多个字符替换的方法小结
如何快速建站并高效导出源代码?
如何在万网自助建站中设置域名及备案?
在centOS 7安装mysql 5.7的详细教程
html5怎么画眼睛_HT5用Canvas或SVG画眼球瞳孔加JS控制动态【绘制】
Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践
Laravel集合Collection怎么用_Laravel集合常用函数详解
详解vue.js组件化开发实践
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集
如何在阿里云ECS服务器部署织梦CMS网站?
Laravel的.env文件有什么用_Laravel环境变量配置与管理详解
如何快速辨别茅台真假?关键步骤解析
如何在七牛云存储上搭建网站并设置自定义域名?
Linux后台任务运行方法_nohup与&使用技巧【技巧】
Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
Laravel如何为API编写文档_Laravel API文档生成与维护方法
Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】
如何用IIS7快速搭建并优化网站站点?
Laravel如何实现邮件验证激活账户_Laravel内置MustVerifyEmail接口配置【步骤】
Laravel Blade组件怎么用_Laravel可复用视图组件的创建与使用
Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
奇安信“盘古石”团队突破 iOS 26.1 提权
php读取心率传感器数据怎么弄_php获取max30100的心率值【指南】
Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践
node.js报错:Cannot find module 'ejs'的解决办法
微信h5制作网站有哪些,免费微信H5页面制作工具?
Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门
PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
详解jQuery停止动画——stop()方法的使用
微博html5版本怎么弄发语音微博_语音录制入口及时长限制操作【教程】
android nfc常用标签读取总结
如何在阿里云虚拟主机上快速搭建个人网站?

