springboot项目利用poi、easypoi导出word、Excel

一.poi导出word

1.在pom.xml中加入依赖

<!-- POI工具 -->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>4.1.1</version>
</dependency>
<!--导出word poi-tl-->
<dependency>
  <groupId>com.deepoove</groupId>
  <artifactId>poi-tl</artifactId>
  <version>1.8.2</version>
</dependency>
<!--Sping表达式  为了在模板标签中使用SpEL表达式-->
<dependency>
    <groupId>org.springframework</groupId>
        <artifactId>spring-expression</artifactId>
    <version>5.1.3.RELEASE</version>
</dependency>

2.准备word模板


image.png

3.代码

        //模板路径
        private final static String WORD_PATH = "static/docs/assistPolice.docx";

    private final String defaultStr = "-";
    private final BigDecimal defaultDecimal = new BigDecimal(0);

    /**
     * 导出个人档案Word
     * @param id
     * @return
     */
    public AjaxResult exportAssisPoliceWordById(String id){
              //获取导出对象
        AssistPolice assistPolice = (AssistPolice) setEmpty(selectExportWordAssistPoliceById(id));
        XWPFTemplate xwpfTemplate = null;
        FileOutputStream out = null;
        try {
            ClassPathResource template = new ClassPathResource(WORD_PATH);
            // Spring EL 无法容忍变量不存在,直接抛出异常,表达式计算引擎为Spring Expression Language
            Configure config = Configure.newBuilder().setElMode(ELMode.SPEL_MODE).build();
            xwpfTemplate = XWPFTemplate.compile(template.getInputStream(),config).render(assistPolice);
            String filename = encodingWordFilename(assistPolice.getName()+"档案");
            out = new FileOutputStream(getAbsoluteFile(filename));
                        // 输出流
            xwpfTemplate.write(out);
            out.flush();
            out.close();
            xwpfTemplate.close();
            return AjaxResult.success(filename);
        }catch (Exception e){
            e.printStackTrace();
            log.info(e.toString());
            throw new BusinessException("导出个人档案失败,请联系网站管理员!");
        }finally{
            if (xwpfTemplate != null){
                try{
                    xwpfTemplate.close();
                }catch (IOException e1){
                    e1.printStackTrace();
                }
            }
            if (out != null){
                try{
                    out.close();
                }catch (IOException e1){
                    e1.printStackTrace();
                }
            }
        }
    }

    /**
     * 获取下载路径
     *
     * @param filename 文件名称
     */
    public String getAbsoluteFile(String filename){
        //KcConfig.getDownloadPath()取配置文件中的下载路径  profile: C:/profile/
        //String downloadPath = KcConfig.getDownloadPath() + filename;
       String downloadPath = " profile: C:/profile/" + filename;
        File desc = new File(downloadPath);
        if (!desc.getParentFile().exists()){
            desc.getParentFile().mkdirs();
        }
        return downloadPath;
    }

    /**
     * 编码word文件名
     */
    public String encodingWordFilename(String filename){
        filename = UUID.randomUUID().toString().replaceAll("-","") + "_" + replaceBlank(filename.trim()) + ".docx";
        return filename;
    }
    
   /**
     * 去掉字符串中的制表符
     * @param str
     * @return
     */
    public static String replaceBlank(String str){
        String dest = "";
        if (str != null) {
            Pattern p = Pattern.compile("\\s*|\t|\r|\n");
            Matcher m = p.matcher(str);
            dest = m.replaceAll("");
        }
        return dest;
    }

    /**
     * 设置AssistPolice中为空的属性为''
     * @param object
     * @return
     */
    @SuppressWarnings(value={"rawtypes"})
    public Object setEmpty(Object object){
        try {
            Class clazz = object.getClass();
            Field[] fields = clazz.getDeclaredFields();
            for(int i=0;i<fields.length;i++){
                Field field = fields[i];
                String fieldName = field.getName();
                Class fieldClass=field.getType();
                field.setAccessible(true); //设置访问权限
                if(isFieldValueNull(fieldName,object)){
                    if (fieldClass == Integer.class ) {
                        field.set(object, defaultDecimal.intValue());
                    }else if (fieldClass == Long.class) {
                        field.set(object, defaultDecimal.longValue());
                    }else if (fieldClass == Float.class) {
                        field.set(object, defaultDecimal.doubleValue());
                    }else if (fieldClass == BigDecimal.class) {
                        field.set(object, defaultDecimal);
                    } else if (fieldClass == String.class){
                        field.set(object, defaultStr); // 设置值
                    }
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println(e.getMessage());
        }
        return object;
    }

4.参考文档
http://deepoove.com/poi-tl/

二.easypoi导出Excel

1.在pom.xml中加入依赖
官方提供 我这里有jar包冲突

       <dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-base</artifactId>
            <version>4.1.0</version>
        </dependency>
        <dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-web</artifactId>
            <version>4.1.0</version>
        </dependency>
        <dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-annotation</artifactId>
            <version>4.1.0</version>
        </dependency>

角落找到的新包

        <!---excel操作-->
        <dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-spring-boot-starter</artifactId>
            <version>4.1.2</version>
        </dependency>

!!!坑:有commons-lang3包,导入版本3.9以上

2.实体 (两种字典替换方式)
a、replace,该方式支持直接写入注解参数中

    @ApiModelProperty(value="是否是退役军人",example="0")
    @Excel(name = "是否是退役军人",replace ={"是_1", "否_0"}, width = 10,orderNum = "20")
    private Integer veterans;

b、dict,字典方式,传入字典参数中

    @ApiModelProperty("人员籍贯(字典)")
    @Excel(name = "籍贯",dict = "nativeplace",  width = 40,orderNum = "4")
    private String nativeplace;

3.实现IExcelDictHandler接口翻译字典

package com.hnkc.fjbm.service.service;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

import javax.annotation.PostConstruct;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import com.hnkc.fjbm.model.DictData;
import com.hnkc.fjbm.service.service.DictService;

import cn.afterturn.easypoi.handler.inter.IExcelDictHandler;

@Component
public class ExcelDictHandlerImpl  implements IExcelDictHandler{
    
    private static Logger logger = LoggerFactory.getLogger(ExcelDictHandlerImplService.class);
    
    @Autowired
    private DictService tempDictService;
    private static DictService dictService;
    private static Map<String, Object> mapData;
    
//PostConstruct注解启动时加载一次
    @PostConstruct
    public void init() {
        DictService dictService = this.tempDictService;
        logger.info("--------加载字典数据-----------");
        mapData = (Map<String, Object>)dictService.getAllDicts().get("data");
        logger.info("------------加载完成---------");
    }
    
    @Override
    public String toName(String dict, Object obj, String name, Object value) {
        try {
            List<DictData> dictDataList = new ArrayList<>();
            if ("nativeplace".equals(dict) && mapData.containsKey("籍贯")) {
                dictDataList = (List<DictData>)mapData.get("籍贯");
                for(DictData dictData : dictDataList) {
                    if(!"".equals(value) && value != null) {
                        if(value.toString().equals(dictData.getValue())) {
                            return dictData.getLabel();
                        }
                    }
                }
                    }
            }
        }catch (Exception e){
                e.printStackTrace();
        }
        return "未知";
    }

    @Override
    public String toValue(String dict, Object obj, String name, Object value) {
        // TODO Auto-generated method stub
        return null;
    }

}

可以参考下https://blog.csdn.net/changzhou0519/article/details/87858969
4.导出表格

          List<Signups> list = service.getSignUpList(signUps_cs);
          try {
              ExportParams params = new ExportParams("惠州市公安局招聘警务辅助人员报名表", "sheetName1", ExcelType.XSSF);
              // 指定单元格转换字典
              params.setDictHandler(new ExcelDictHandlerImplService());
              Workbook workbook = ExcelExportUtil.exportExcel(params, Signups.class, list);
              File saveFile = new File("excel");
              if (!saveFile.exists()) {
                  saveFile.mkdirs();
              }
              String filename = encodingWordFilename("惠州市公安局招聘警务辅助人员报名表");
              FileOutputStream fos = new FileOutputStream(getAbsoluteFile(filename));
              workbook.write(fos);
              fos.close();
          } catch (IOException e) {
              e.printStackTrace();
          }

参考文档:
http://easypoi.mydoc.io/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335

推荐阅读更多精彩内容