springMVC导出word模板的方法

 更新时间:2017年07月05日 09:45:02   作者:初见321  
这篇文章主要为大家详细介绍了springMVC导出word模板的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了springMVC导出word模板的具体代码,供大家参考,具体内容如下

controller 调用

@RequestMapping(value = "/exportWord")
public void exportWord(HttpServletResponse response, HttpServletRequest request) throws IOException {
  String templatePath = request.getServletContext().getRealPath("") + "/template/税源信息比对.docx"; 
  String fileName = new String("税源信息比对".getBytes("gb2312"), "ISO8859-1") + ".docx";
  /*数据*/
  Map<String, Object> params = new HashMap<String, Object>(); 
  params.put("${name}", "aaaa"); 
  params.put("${sex}", "bbbb");

  TempleWordUtil wordUtil = new TempleWordUtil();

  XWPFDocument doc; 
  InputStream is = new FileInputStream(templatePath);
 // is = getClass().getClassLoader().getResourceAsStream(templatePath); 
  doc = new XWPFDocument(is);  //只能使用.docx的

  wordUtil.replaceInPara(doc, params); 
  //替换表格里面的变量 
  wordUtil.replaceInTable(doc, params); 
  OutputStream os = response.getOutputStream(); 

  response.setContentType("application/vnd.ms-excel"); 
  response.setHeader("Content-disposition", "attachment;filename=" + fileName); 

  doc.write(os); 

  wordUtil.close(os); 
  wordUtil.close(is); 

  os.flush(); 
  os.close(); 

}

TempleWordUtil 工具类

import org.apache.poi.xwpf.usermodel.*; 
  
import java.io.*; 
import java.util.Iterator; 
import java.util.List; 
import java.util.Map; 
import java.util.regex.Matcher; 
import java.util.regex.Pattern; 
 
/**
 * 写入word工具类
 * @author z
 *
 */
public class TempleWordUtil {
 
  /** 
   * 替换段落里面的变量 
   * 
   * @param doc  要替换的文档 
   * @param params 参数,导入的数据 
   */ 
  public void replaceInPara(XWPFDocument doc, Map<String, Object> params) { 
    Iterator<XWPFParagraph> iterator = doc.getParagraphsIterator(); 
    XWPFParagraph para; 
    while (iterator.hasNext()) { 
      para = iterator.next(); 
      this.replaceInPara(para, params); 
    } 
  } 
  
  /** 
   * 替换段落里面的变量 
   * 
   * @param para  要替换的段落 
   * @param params 参数 
   */ 
  public void replaceInPara(XWPFParagraph para, Map<String, Object> params) { 
    List<XWPFRun> runs; 
    //Matcher matcher; 
    if (this.matcher(para.getParagraphText()).find()) { 
      runs = para.getRuns(); 
  
      int start = -1; 
      int end = -1; 
      String str = ""; 
      for (int i = 0; i < runs.size(); i++) { 
        XWPFRun run = runs.get(i); 
        String runText = run.toString(); 
        if ('$' == runText.charAt(0)&&'{' == runText.charAt(1)) { 
          start = i; 
        } 
        if ((start != -1)) { 
          str += runText; 
        } 
        if ('}' == runText.charAt(runText.length() - 1)) { 
          if (start != -1) { 
            end = i; 
            break; 
          } 
        } 
      } 
  
      for (int i = start; i <= end; i++) { 
        para.removeRun(i); 
        i--; 
        end--; 
      } 
  
      for (String key : params.keySet()) { 
        if (str.equals(key)) { 
          para.createRun().setText((String) params.get(key)); 
          break; 
        } 
      } 
  
  
    } 
  } 
  
  /** 
   * 替换表格里面的变量 
   * 
   * @param doc  要替换的文档 
   * @param params 参数 
   */ 
  public void replaceInTable(XWPFDocument doc, Map<String, Object> params) { 
    Iterator<XWPFTable> iterator = doc.getTablesIterator(); 
    XWPFTable table; 
    List<XWPFTableRow> rows; 
    List<XWPFTableCell> cells; 
    List<XWPFParagraph> paras; 
    while (iterator.hasNext()) { 
      table = iterator.next(); 
      rows = table.getRows(); 
      for (XWPFTableRow row : rows) { 
        cells = row.getTableCells(); 
        for (XWPFTableCell cell : cells) { 
          paras = cell.getParagraphs(); 
          for (XWPFParagraph para : paras) { 
            this.replaceInPara(para, params); 
          } 
        } 
      } 
    } 
  } 
  
  /** 
   * 正则匹配字符串 
   * 
   * @param str 
   * @return 
   */ 
  private Matcher matcher(String str) { 
    Pattern pattern = Pattern.compile("\\$\\{(.+?)\\}", Pattern.CASE_INSENSITIVE); 
    Matcher matcher = pattern.matcher(str); 
    return matcher; 
  } 
  
  /** 
   * 关闭输入流 
   * 
   * @param is 
   */ 
  public void close(InputStream is) { 
    if (is != null) { 
      try { 
        is.close(); 
      } catch (IOException e) { 
        e.printStackTrace(); 
      } 
    } 
  } 
  
  /** 
   * 关闭输出流 
   * 
   * @param os 
   */ 
  public void close(OutputStream os) { 
    if (os != null) { 
      try { 
        os.close(); 
      } catch (IOException e) { 
        e.printStackTrace(); 
      } 
    } 
  } 
  
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • java遍历http请求request的所有参数实现方法

    java遍历http请求request的所有参数实现方法

    下面小编就为大家带来一篇java遍历http请求request的所有参数实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • Java中final关键字的使用与注意总结

    Java中final关键字的使用与注意总结

    这篇文章主要给大家介绍了关于Java中final关键字的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者使用Java具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2020-08-08
  • 纯Java实现数字证书生成签名的简单实例

    纯Java实现数字证书生成签名的简单实例

    下面小编就为大家带来一篇纯Java实现数字证书生成签名的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • Spring中RedisTemplate的基本使用浅析

    Spring中RedisTemplate的基本使用浅析

    Spring Boot Data(数据) Redis中提供了RedisTemplate和StringRedisTemplate,其中StringRedisTemplate是RedisTemplate的子类,两个方法基本一致。本文介绍了Spring操作Redis的方法,需要的可以参考一下
    2023-02-02
  • Java多线程实现的两种方式

    Java多线程实现的两种方式

    本文主要介绍了Java多线程实现的两种方式:继承Thread类、实现Runnable接口。具有一定的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • Java实现企业微信消息推送功能的详细步骤

    Java实现企业微信消息推送功能的详细步骤

    这篇文章主要介绍了Java实现企业微信消息推送功能,本文图文实例代码相结合给大家介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • MyBatis执行动态SQL的方法

    MyBatis执行动态SQL的方法

    今天小编就为大家分享一篇关于MyBatis执行动态SQL的方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • IDEA性能优化方法解决卡顿问题

    IDEA性能优化方法解决卡顿问题

    本文主要介绍了如何在不升级电脑配置的情况下通过修改IntelliJIDEA的设置来优化其性能,从而提升开发效率
    2024-12-12
  • Spring Boot 静态资源处理方式

    Spring Boot 静态资源处理方式

    这篇文章主要介绍了Spring Boot 静态资源处理方式,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-09-09
  • MyBatis学习教程(四)-如何快速解决字段名与实体类属性名不相同的冲突问题

    MyBatis学习教程(四)-如何快速解决字段名与实体类属性名不相同的冲突问题

    我们经常会遇到表中的字段名和表对应实体类的属性名称不一定都是完全相同的情况,如何解决呢?下面脚本之家小编给大家介绍MyBatis学习教程(四)-如何快速解决字段名与实体类属性名不相同的冲突问题,一起学习吧
    2016-05-05

最新评论