java怎么实现导出数据后放到word文档中,并且可以保存到本硬盘上(类似于百度文库里面的下载功能)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java怎么实现导出数据后放到word文档中,并且可以保存到本硬盘上(类似于百度文库里面的下载功能)相关的知识,希望对你有一定的参考价值。

大概是我的jsp页面显示了从数据库中读出的数据,然后我点击一个按钮保存或下载,然后就弹出一个提示框,提示框里有下载和打开这两个按钮。急,,谢谢。

参考技术A 要用servletoutputstream 将一个文件流进行下载,如何生成word可以考虑用poi或者是itext,itext是专门做word的,效果好,poi主要是用于生成和读取excel,当然生成word也可以,只不过效果不好。 参考技术B 可以试试用apache的poi来生成word文件,个人没用过poi
至于下载,你可以设置文件的类型是word文档嘛
参考技术C ims 类型为ms/word 参考技术D http://sunchaohui-koko.javaeye.com/blog/602572 第5个回答  2012-11-29 用xml模板 我也刚学会的 挺简单的 呵呵

java利用poi导出word文档

项目中,有时候需要使用poi实现将固定数据导入word中
效果图:

代码:

package poiword;

import java.io.File;
import java.io.FileOutputStream;
import java.math.BigInteger;

import org.apache.poi.xwpf.usermodel.ParagraphAlignment;
import org.apache.poi.xwpf.usermodel.XWPFDocument;
import org.apache.poi.xwpf.usermodel.XWPFParagraph;
import org.apache.poi.xwpf.usermodel.XWPFRun;
import org.apache.poi.xwpf.usermodel.XWPFTable;
import org.apache.poi.xwpf.usermodel.XWPFTableRow;
import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTShd;
import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTTblWidth;
import org.openxmlformats.schemas.wordprocessingml.x2006.main.STShd;
import org.openxmlformats.schemas.wordprocessingml.x2006.main.STTblWidth;

public class TestPOIWordOut 
    public static void main(String[] args) 

        //Blank Document  
        XWPFDocument document= new XWPFDocument();  

        //Write the Document in file system  
        FileOutputStream out;
        try 
            out = new FileOutputStream(new File("C:/Users/Administrator/Desktop/poi_word.docx"));

        //添加标题  
        XWPFParagraph titleParagraph = document.createParagraph();  
        //设置段落居中  
        titleParagraph.setAlignment(ParagraphAlignment.CENTER);  

        XWPFRun titleParagraphRun = titleParagraph.createRun();  
        titleParagraphRun.setText("自学指导(标题)");  
        titleParagraphRun.setColor("000000");  
        titleParagraphRun.setFontSize(20);  

        //段落  
        XWPFParagraph firstParagraph = document.createParagraph();  
        XWPFRun run = firstParagraph.createRun();  
        run.setText("   自学遇到问题怎么办?");  
        run.setColor("698869");  
        run.setFontSize(16);  

        //设置段落背景颜色  
        CTShd cTShd = run.getCTR().addNewRPr().addNewShd();  
        cTShd.setVal(STShd.CLEAR);  
        cTShd.setFill("97FF45");  

        //换行  
        XWPFParagraph paragraph1 = document.createParagraph();  
        XWPFRun paragraphRun1 = paragraph1.createRun();  
        paragraphRun1.setText("\\r");  

        //基本信息表格  
        XWPFTable infoTable = document.createTable();  
        //去表格边框  
        infoTable.getCTTbl().getTblPr().unsetTblBorders();  

        //列宽自动分割  
        CTTblWidth infoTableWidth = infoTable.getCTTbl().addNewTblPr().addNewTblW();  
        infoTableWidth.setType(STTblWidth.DXA);  
        infoTableWidth.setW(BigInteger.valueOf(9072));  

        //表格第一行  
        XWPFTableRow infoTableRowOne = infoTable.getRow(0);  
        infoTableRowOne.getCell(0).setText("职位");  
        infoTableRowOne.addNewTableCell().setText(": xxxx");  

        //表格第二行  
        XWPFTableRow infoTableRowTwo = infoTable.createRow();  
        infoTableRowTwo.getCell(0).setText("姓名");  
        infoTableRowTwo.getCell(1).setText(": xxxx");  

        //表格第三行  
        XWPFTableRow infoTableRowThree = infoTable.createRow();  
        infoTableRowThree.getCell(0).setText("生日");  
        infoTableRowThree.getCell(1).setText(": xxx-xx-xx");  

        //表格第四行  
        XWPFTableRow infoTableRowFour = infoTable.createRow();  
        infoTableRowFour.getCell(0).setText("性别");  
        infoTableRowFour.getCell(1).setText(": x");  

        //表格第五行  
        XWPFTableRow infoTableRowFive = infoTable.createRow();  
        infoTableRowFive.getCell(0).setText("现居地");  
        infoTableRowFive.getCell(1).setText(": xx");  

        //两个表格之间加个换行  
        XWPFParagraph paragraph = document.createParagraph();  
        XWPFRun paragraphRun = paragraph.createRun();  
        paragraphRun.setText("\\r");  

        //工作经历表格  
        XWPFTable ComTable = document.createTable();  

        //列宽自动分割  
        CTTblWidth comTableWidth = ComTable.getCTTbl().addNewTblPr().addNewTblW();  
        comTableWidth.setType(STTblWidth.DXA);  
        comTableWidth.setW(BigInteger.valueOf(9072)); 

        //表格第一行  
        XWPFTableRow comTableRowOne = ComTable.getRow(0);  
        comTableRowOne.getCell(0).setText("开始时间");  
        comTableRowOne.addNewTableCell().setText("结束时间");  
        comTableRowOne.addNewTableCell().setText("公司名称");  
        comTableRowOne.addNewTableCell().setText("职位");  

        //表格第二行  
        XWPFTableRow comTableRowTwo = ComTable.createRow();  
        comTableRowTwo.getCell(0).setText("20xx-xx-xx");  
        comTableRowTwo.getCell(1).setText("至今");  
        comTableRowTwo.getCell(2).setText("自学指导网站");  
        comTableRowTwo.getCell(3).setText("Java开发工程师");  

        //表格第三行  
        XWPFTableRow comTableRowThree = ComTable.createRow();  
        comTableRowThree.getCell(0).setText("20xx-xx-xx");  
        comTableRowThree.getCell(1).setText("至今");  
        comTableRowThree.getCell(2).setText("s.jf3q.com");  
        comTableRowThree.getCell(3).setText("Java开发工程师");  

            document.write(out);  
            out.close();  
         catch (Exception e1) 
            // TODO Auto-generated catch block
            e1.printStackTrace();
         
        System.out.println("create_table document written success."); 
    

注意事项:最核心的就是需要的jar包不能下载错哦。

以上是关于java怎么实现导出数据后放到word文档中,并且可以保存到本硬盘上(类似于百度文库里面的下载功能)的主要内容,如果未能解决你的问题,请参考以下文章

java怎么实现把页面的表格另存为一个word文档,求各位大神指导

java用poi导出word文档,我要导出一个表格,表格的单元格中还要有一个表格,请问怎么实现

java导出到Word

如何把页面内容导出为word? (Java)

oracle怎么把查询的结果导出word或excle

php导出word和pdf文件