阿里 EasyExcel 表头国际化

实体类字段使用EasyExcel提供的注解@ExcelProperty,value 值写成占位符形式 ,匹配 i18n 文件里面的编码。
如:

/**
 * 仓库名称
 */
@ExcelProperty("{warehouse.record.warehouseName}")
private String warehouseName;

占位符解析器

@AllArgsConstructor(access = AccessLevel.PRIVATE)
@NoArgsConstructor(access = AccessLevel.PRIVATE)
public class PlaceholderResolver {
   

    /**
     * 默认前缀占位符
     */
    public static final String DEFAULT_PLACEHOLDER_PREFIX = "{";

    /**
     * 默认后缀占位符
     */
    public static final String DEFAULT_PLACEHOLDER_SUFFIX = "}";

    /**
     * 默认单例占位符解析器,即占位符前缀为"{", 后缀为"}"
     */
    @Getter
    private static final PlaceholderResolver defaultResolver = new PlaceholderResolver();

    /**
     * 占位符前缀
     */
    private String placeholderPrefix = DEFAULT_PLACEHOLDER_PREFIX;

    /**
     * 占位符后缀
     */
    private String placeholderSuffix = DEFAULT_PLACEHOLDER_SUFFIX;

    /**
     * 根据替换规则来替换指定模板中的占位符值
     *
     * @param content 要解析的字符串
     * @param rule    解析规则回调
     */
    public String resolveByRule(String content, Function<String, String> rule) {
   
        int start = content.indexOf(this.placeholderPrefix);
        if (start == -1) {
   
            return content;
        }
        StringBuilder result = new StringBuilder(content);
        while (start != -1) {
   
            int end = result.indexOf(this.placeholderSuffix, start);
            //获取占位符属性值,如{id}, 即获取id
            String placeholder = result.substring(start + this.placeholderPrefix.length(), end);
            //替换整个占位符内容,即将{id}值替换为替换规则回调中的内容
            String replaceContent = placeholder.trim().isEmpty() ? "" : rule.apply(placeholder);
            result.replace(start, end + this.placeholderSuffix.length(), replaceContent);
            start = result.indexOf(this.placeholderPrefix, start + replaceContent.length());
        }
        return result.toString();
    }
}

自定义拦截器

@RequiredArgsConstructor
public class I18nCellWriteHandler implements CellWriteHandler {
   

    @Resource
    private MessageSource messageSource;

    @Override
    public void beforeCellCreate(CellWriteHandlerContext context) {
   
        if (!context.getHead()) {
   
            return;
        }
        final List<String> originHeadNames = context.getHeadData().getHeadNameList();
        if (CollectionUtils.isEmpty(originHeadNames)) {
   
            return;
        }
        List<String> newHeadNames = originHeadNames.stream().
                map(headName -> PlaceholderResolver.getDefaultResolver()
                        .resolveByRule(headName, this::getMessage)).
                collect(Collectors.toList());
        context.getHeadData().setHeadNameList(newHeadNames);
    }

    public String getMessage(String code) {
   
        Locale locale = LocaleContextHolder.getLocale();
        return messageSource.getMessage(code, null, locale);
    }
}

相关推荐

  1. 阿里 EasyExcel 表头国际化

    2024-02-08 10:22:08       52 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-08 10:22:08       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-08 10:22:08       100 阅读
  3. 在Django里面运行非项目文件

    2024-02-08 10:22:08       82 阅读
  4. Python语言-面向对象

    2024-02-08 10:22:08       91 阅读

热门阅读

  1. Python面试题19-24

    2024-02-08 10:22:08       46 阅读
  2. ELEC362 C++ Department of Electrical Engineering and Electronics

    2024-02-08 10:22:08       54 阅读
  3. OpenGL帧缓冲:渲染缓冲区对象 Renderbuffer Objects

    2024-02-08 10:22:08       51 阅读
  4. 作业2024/2/5

    2024-02-08 10:22:08       45 阅读
  5. ROS学习笔记15:动态参数

    2024-02-08 10:22:08       60 阅读
  6. 力扣:47. 全排列 II

    2024-02-08 10:22:08       51 阅读
  7. Vue 3 + Koa2 + MySQL 开发和上线部署个人网站

    2024-02-08 10:22:08       56 阅读
  8. ASP.NET Core MVC 控制查询数据表后在视图显示

    2024-02-08 10:22:08       54 阅读
  9. 【Docker】01 Docker安装与配置

    2024-02-08 10:22:08       48 阅读
  10. LLVM实战之LLVM bitcode转换成目标平台汇编码

    2024-02-08 10:22:08       53 阅读