0

0

java反射工具类的实现代码(Excel导出)

不言

不言

发布时间:2018-09-18 15:36:05

|

2605人浏览过

|

来源于php中文网

原创

本篇文章给大家带来的内容是关于java反射工具类的实现代码(excel导出),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

一、定义注解,用于vo类中标记使用到的属性

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
 * @author fc
 * @date 2018-09-18
 */
@Target(value = {ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
public @interface Allow {
    String title() default "undefined";
}

二、反射工具类

Faceswap
Faceswap

免费开源的AI换脸工具

下载
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.util.List;
/**
 * @author fc
 * @date 2018-09-18
 * @msg 反射工具类
 * @tips 字段必须使用@Allow注解 title属性定义标题
 */
public class ExcelCreateUtil {
    /**
     *
     * @param o object是vo类
     * @param suf 返回的excel文件后缀
     * @return
     * @throws Exception
     */
    public static Workbook createWorkBook(List o,ReturnSuf suf) throws Exception {
        //定义一个新的工作簿
        Workbook wb = suf.getValue().equals(ReturnSuf.XLSX.getValue())?new XSSFWorkbook():new HSSFWorkbook();
        //创建sheet
        Sheet sheet = wb.createSheet(String.valueOf(System.currentTimeMillis()));
        //创建行
        Row row = sheet.createRow(0);
        //第一行以注解@Allow title属性命名
        Class aClass = o.get(0).getClass();
        Field[] fields1 = aClass.getDeclaredFields();
        int bj2 = 0;
        for (int j = 0; j < fields1.length; j++) {
            Allow annotation = fields1[j].getAnnotation(Allow.class);
            if (annotation != null) {
                fields1[j].setAccessible(true);
                row.createCell(bj2).setCellValue(annotation.title());
                bj2++;
            }
        }
        int bj1 = 1;
        for (int i = 0; i < o.size(); i++) {
            //获取当前对象
            Object o1 = o.get(i);
            //获取当前类类型
            Class c = o.get(i).getClass();
            //获取当前类类型的所有属性
            Field[] fields = c.getDeclaredFields();
            //创建行-从第二行起
            Row row1 = sheet.createRow(bj1);
            bj1++;
            int bj = 0;
            for (int j = 0; j < fields.length; j++) {
                Allow annotation = fields1[j].getAnnotation(Allow.class);
                if (annotation != null) {
                    fields[j].setAccessible(true);
                    //得到属性名
                    String name = fields[j].getName();
                    //获取属性对应的get方法
                    Method method = c.getDeclaredMethod(toGet(name));
                    Object invoke = method.invoke(o1);
                    String value = invoke == null ? "" : invoke.toString();
                    //赋值
                    row1.createCell(bj).setCellValue(value);
                    bj++;
                }
            }
        }
        return wb;
    }
    //获取属性的set方法
    public static String toSet(String s) {
        final String SET = "set";
        if (Character.isUpperCase(s.charAt(0))) {
            return SET + s;
        } else {
            return SET + (new StringBuilder()).append(Character.toUpperCase(s.charAt(0))).append(s.substring(1)).toString();
        }
    }
    //获取属性的get方法
    public static String toGet(String s) {
        final String GET = "get";
        if (Character.isUpperCase(s.charAt(0))) {
            return GET + s;
        } else {
            return GET + (new StringBuilder()).append(Character.toUpperCase(s.charAt(0))).append(s.substring(1)).toString();
        }
    }
    public enum ReturnSuf {
        XLS(".xls后缀", ".xls"),
        /**
         *大数据量建议使用.xlsx
         */
        XLSX(".xlsx后缀", ".xlsx"),;
        private String key;
        private String value;
        ReturnSuf(String key, String value) {
            this.key = key;
            this.value = value;
        }
        public String getKey() {
            return key;
        }
        public void setKey(String key) {
            this.key = key;
        }
        public String getValue() {
            return value;
        }
        public void setValue(String value) {
            this.value = value;
        }
    }
}					
					

					

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
excel对比两列数据异同
excel对比两列数据异同

Excel作为数据的小型载体,在日常工作中经常会遇到需要核对两列数据的情况,本专题为大家提供excel对比两列数据异同相关的文章,大家可以免费体验。

1398

2023.07.25

excel重复项筛选标色
excel重复项筛选标色

excel的重复项筛选标色功能使我们能够快速找到和处理数据中的重复值。本专题为大家提供excel重复项筛选标色的相关的文章、下载、课程内容,供大家免费下载体验。

409

2023.07.31

excel复制表格怎么复制出来和原来一样大
excel复制表格怎么复制出来和原来一样大

本专题为大家带来excel复制表格怎么复制出来和原来一样大相关文章,帮助大家解决问题。

562

2023.08.02

excel表格斜线一分为二
excel表格斜线一分为二

在Excel表格中,我们可以使用斜线将单元格一分为二。本专题为大家带来excel表格斜线一分为二怎么弄的相关文章,希望可以帮到大家。

1243

2023.08.02

excel斜线表头一分为二
excel斜线表头一分为二

excel斜线表头一分为二的方法有使用合并单元格功能方法、使用文本框功能方法、使用自定义格式方法。本专题为大家提供excel斜线表头一分为二相关的各种文章、以及下载和课程。

368

2023.08.02

绝对引用的输入方法
绝对引用的输入方法

绝对引用允许在公式中引用一个固定的单元格,而不会随着公式的复制和粘贴而改变引用的单元格。本专题为大家提供绝对引用相关内容的文章,大家可以免费体验。

4526

2023.08.09

java导出excel
java导出excel

在Java中,我们可以使用Apache POI库来导出Excel文件。本专题提供java导出excel的相关文章,大家可以免费体验。

408

2023.08.18

excel输入值非法
excel输入值非法

在Excel中,当输入的数值非法时,有以下多种处理方法。本专题为大家提供excel输入值非法的相关文章,大家可以免费体验。

1019

2023.08.18

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3万人学习

C# 教程
C# 教程

共94课时 | 7.8万人学习

Java 教程
Java 教程

共578课时 | 52.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号