软件测试

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

2020-11-18  本文已影响0人  lowkey港

一.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/

上一篇下一篇

猜你喜欢

热点阅读