`
apchy
  • 浏览: 59491 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

poi读写word模板

    博客分类:
  • java
阅读更多

有一word文档表格

形如:

姓名 ${name} 

电话 ${tel}

 

从数据库读取记录替换上述变量

 

import java.io.FileOutputStream;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;

import org.apache.poi.POIXMLDocument;
import org.apache.poi.xwpf.usermodel.XWPFDocument;
import org.apache.poi.xwpf.usermodel.XWPFTable;
import org.apache.poi.xwpf.usermodel.XWPFTableCell;
import org.apache.poi.xwpf.usermodel.XWPFTableRow;


public class DOCWriter {

 public static void searchAndReplace(String srcPath ,String destPath,Map<String,String> map) {
  try {
   XWPFDocument document = new XWPFDocument(POIXMLDocument.openPackage(srcPath));
   Iterator it = document.getTablesIterator();
   while(it.hasNext()){
    XWPFTable table = (XWPFTable)it.next();
    int rcount = table.getNumberOfRows();
    for(int i =0 ;i < rcount;i++){
     XWPFTableRow row = table.getRow(i);
     List<XWPFTableCell> cells =  row.getTableCells();
     for (XWPFTableCell cell : cells){
        for(Entry<String,String> e : map.entrySet()){
         if (cell.getText().equals(e.getKey())){
          cell.removeParagraph(0);
          cell.setText(e.getValue());
         }
        }
     }
    }
   }
       FileOutputStream outStream = null;
       outStream = new FileOutputStream(destPath);
          document.write(outStream);
          outStream.close();
  } catch (Exception e) {
   e.printStackTrace();
  }

 }

 public static void main(String[] args) throws Exception {
  HashMap map=new HashMap();
  map.put("${name}", "王五");
  map.put("${tel}", "8886666");
  String srcPath = "c:\\1.docx";
  String destPath = "c:\\2.doc";
  searchAndReplace(srcPath ,destPath,map);

 }
}

 

分享到:
评论
5 楼 lixinyouapple 2012-06-19  
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/xmlbeans/XmlException
at poi07.DOCWriter.searchAndReplace(DOCWriter.java:16)
4 楼 apchy 2012-05-26  
poi需要3.7
3 楼 1154934572 2012-05-15  
为什么我的程序找不到row.getTableCells();这个方法,我也引入了import org.apache.poi.xwpf.usermodel.XWPFTableRow;请问你用的是那个版本的包呢?我用的是3.5的!
2 楼 phrmgb 2011-11-27  
缺少的包找到了
1 楼 phrmgb 2011-11-27  
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/xmlbeans/XmlException
at poi07.DOCWriter.searchAndReplace(DOCWriter.java:16)
at poi07.DOCWriter.main(DOCWriter.java:48)

相关推荐

Global site tag (gtag.js) - Google Analytics