全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

java利用注解实现简单的excel数据读取

实现工具类

利用注解实现简单的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 


相关文章: 开心动漫网站制作软件下载,十分开心动画为何停播?  可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?  建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析  实现点击下箭头变上箭头来回切换的两种方法【推荐】  相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?  制作网站公司那家好,网络公司是做什么的?  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  制作公司内部网站有哪些,内网如何建网站?  定制建站模板如何实现SEO优化与智能系统配置?18字教程  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?  官网自助建站平台指南:在线制作、快速建站与模板选择全解析  建站之星后台搭建步骤解析:模板选择与产品管理实操指南  如何在VPS电脑上快速搭建网站?  如何在IIS7中新建站点?详细步骤解析  如何在Windows 2008云服务器安全搭建网站?  北京专业网站制作设计师招聘,北京白云观官方网站?  深入理解Android中的xmlns:tools属性  C#如何序列化对象为XML XmlSerializer用法  建站之星官网登录失败?如何快速解决?  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  如何基于云服务器快速搭建网站及云盘系统?  公司网站的制作公司,企业网站制作基本流程有哪些?  音乐网站服务器如何优化API响应速度?  台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?  小自动建站系统:AI智能生成+拖拽模板,多端适配一键搭建  一键制作网站软件下载安装,一键自动采集网页文档制作步骤?  实惠建站价格推荐:2025年高性价比自助建站套餐解析  定制建站平台哪家好?企业官网搭建与快速建站方案推荐  专业网站建设制作报价,网页设计制作要考什么证?  内网网站制作软件,内网的网站如何发布到外网?  上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?  枣阳网站制作,阳新火车站打的到仙岛湖多少钱?  seo网站制作优化,网站SEO优化步骤有哪些?  如何在景安云服务器上绑定域名并配置虚拟主机?  如何快速配置高效服务器建站软件?  家具网站制作软件,家具厂怎么跑业务?  如何在万网ECS上快速搭建专属网站?  清除minerd进程的简单方法  如何通过PHP快速构建高效问答网站功能?  外贸公司网站制作哪家好,maersk船公司官网?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  MySQL查询结果复制到新表的方法(更新、插入)  子杰智能建站系统|零代码开发与AI生成SEO优化指南  沈阳制作网站公司排名,沈阳装饰协会官方网站?  建站主机选哪家性价比最高?  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  高端网站建设与定制开发一站式解决方案 中企动力  网站视频怎么制作,哪个网站可以免费收看好莱坞经典大片? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。