poi--2.word基本

1      概述

 

2      读操作

2.1  通过XWPFWordExtractor读

       在使用XWPFWordExtractor读取docx文档的内容时,我们只能获取到其文本,而不能获取到其文本对应的属性值。

 

2.2   通过XWPFDocument读

       在通过XWPFDocument读取docx文档时,我们就可以获取到文本比较精确的属性信息了。比如我们可以获取到某一个XWPFParagraph、XWPFRun或者是某一个XWPFTable,包括它们对应的属性信息

 

 

 

 

3      写操作

3.1  新建一个文档

//新建一个文档  
XWPFDocument doc = new XWPFDocument();  

XWPFDocument document=new XWPFDocument();
 
document.createTable(2, 2);//--创建一个制定行列的表
document.enforceReadonlyProtection();//--强制执行制度保护
document.write(ostream);

3.2  创建一个段落

//创建一个段落  
XWPFParagraph p1 = doc.createParagraph();   

//添加一个段落
           XWPFParagraph p1=document.createParagraph();
                        //setAlignment()指定应适用于此段落中的文本的段落对齐方式。CENTER LEFT...
                        //p1.setAlignment(ParagraphAlignment.LEFT);
                       //p1.setBorderBetween(Borders.APPLES);                      
                       //p1.setBorderBottom(Borders.APPLES);
                       //p1.setBorderLeft(Borders.APPLES);指定应显示在左边页面指定段周围的边界。
                       //p1.setBorderRight(Borders.ARCHED_SCALLOPS);指定应显示在右侧的页面指定段周围的边界。
                       //p1.setBorderTop(Borders.ARCHED_SCALLOPS);指定应显示上方一组有相同的一组段边界设置的段落的边界。这几个是对段落之间的格式的统一,相当于格式刷
                        //p1.setFirstLineIndent(99);//---正文宽度会稍微变窄
                       //p1.setFontAlignment(1);//---段落的对齐方式 1左 2中 3右 4往上 左 不可写0和负数
                       //p1.setIndentationFirstLine(400);//---首行缩进,指定额外的缩进,应适用于父段的第一行。
                        //p1.setIndentationHanging(400);//---首行前进,指定的缩进量,应通过第一行回到开始的文本流的方向上移动缩进从父段的第一行中删除。
                       //p1.setIndentationLeft(400);//---整段缩进(右移)指定应为从左到右段,该段的内容的左边的缘和这一段文字左边的距和右边文本边距和左段权中的那段文本的右边缘之间的缩进,如果省略此属性,则应假定其值为零。
                       //p1.setIndentationRight(400);//---指定应放置这一段,该段的内容从左到右段的右边缘的正确文本边距和右边文本边距和左段权中的那段文本的右边缘之间的缩进,如果省略此属性,则应假定其值为零。
                       //p1.setIndentFromLeft(400);//---整段右移
                       //p1.setIndentFromRight(400);
                       //p1.setNumID(BigInteger.TEN);
                       //p1.setPageBreak(true);//--指定当渲染此分页视图中的文档,这一段的内容都呈现在文档中的新页的开始。
                       //p1.setSpacingAfter(6);//--指定应添加在文档中绝对单位这一段的最后一行之后的间距。
                        //p1.setSpacingAfterLines(6);//--指定应添加在此线单位在文档中的段落的最后一行之后的间距。
                       //p1.setSpacingBefore(6);//--指定应添加上面这一段文档中绝对单位中的第一行的间距。
                       //p1.setSpacingBeforeLines(6);//--指定应添加在此线单位在文档中的段落的第一行之前的间距。
                        //p1.setSpacingLineRule(LineSpacingRule.AT_LEAST);//--指定行之间的间距如何计算存储在行属性中。
                       //p1.setStyle("");//--此方法提供了样式的段落,这非常有用.
                       //p1.setVerticalAlignment(TextAlignment.CENTER);//---指定的文本的垂直对齐方式将应用于此段落中的文本
                        //p1.setWordWrapped(true);//--此元素指定是否消费者应中断超过一行的文本范围,通过打破这个词(打破人物等级)的两行或通过移动到下一行(在词汇层面上打破)这个词的拉丁文字。              

 

3.3  创建一个区域

 //一个XWPFRun代表具有相同属性的一个区域。  
      XWPFRun run = para.createRun();  
      run.setBold(true); //加粗  
      run.setText("加粗的内容");  
      run = para.createRun();  
      run.setColor("FF0000");  
      run.setText("红色的字。");  

XWPFRunr1=p1.createRun();//p1.createRun()将一个新运行追加到这一段
                        //setText(String value)或
                        //setText(Stringvalue,int pos)
                        //value -应在文件中显示的文字文本
                        //pos - - 文本数组中的位置(NB:0)
                        r1.setText(data);
                        //r1.setTextPosition(20);//这个相当于设置行间距的,具体这个20是怎么算的,不清楚,此元素指定文本应为此运行在关系到周围非定位文本的默认基线升降的量。不是真正意义上的行间距
                        //---This elementspecifies the amount by which text shall be ★raised or lowered★ for this run in relationto the default baseline of the surrounding non-positioned text.
                       //r1.setStrike(true);//---设置删除线的,坑人!!!
                       //r1.setStrikeThrough(true);---也是设置删除线,可能有细微的区别吧
                       //r1.setEmbossed(true);---变的有重影(变黑了一点)
                        //r1.setDoubleStrikethrough(true);---设置双删除线
                       //r1.setColor("33CC00");//---设置字体颜色★
                       //r1.setFontFamily("fantasy");
                       //r1.setFontFamily("cursive");//---设置ASCII(0 - 127)字体样式
                        r1.setBold(jiacu);//---"加黑加粗"
                       r1.setFontSize(size);//---字体大小
                       //r1.setImprinted(true);//感觉与setEmbossed(true)类似,有重影
                       //r1.setItalic(true);//---文本会有倾斜,是一种字体?
                       //r1.setShadow(true);//---文本会变粗有重影,与前面两个有重影效果的方法感觉没什么区别
                       //r1.setSmallCaps(true);//---改变了  英文字母  的格式
                       //r1.setSubscript(VerticalAlign.BASELINE);//---valign垂直对齐的
                        //r1.setUnderline(UnderlinePatterns.DASH);//--填underline type设置下划线
                       
                        /**
                         *r1.setDocumentbackground(doc, "FDE9D9");//设置页面背景色
                          r1.testSetUnderLineStyle(doc);//设置下划线样式以及突出显示文本
                           r1.addNewPage(doc,BreakType.PAGE);
                           r1.testSetShdStyle(doc);//设置文字底纹
                         */

4      写常用方法

4.1  段落

4.1.1  缩进

/**
 * 创建一个段落首行缩进
 * @param doc
 * @param f
 * @return
 */
public XWPFParagraph crePf(XWPFDocument doc, int f) {
   XWPFParagraph p =doc.createParagraph();
   p.setIndentationFirstLine(f);                             //首行缩进
   return p;
}

4.1.2  居中

/**
 * 获得一个段落居中
 * @param doc
 * @return
 */
public XWPFParagraph crePc(XWPFDocument doc) {
   XWPFParagraph p =doc.createParagraph();
   p.setAlignment(ParagraphAlignment.CENTER);             //水平居中
   return p;
} 

4.2  文本

4.2.1  五种

 

/**
 * 段落的文本
 * @param p
 * @param bold    加粗
 * @param text    文本
 * @param fontFamily   字体
 * @param fontSize    字号
 */
public XWPFRun creXR_pbtff(XWPFParagraph p, boolean bold, String text,String fontFamily, int fontSize) {
   XWPFRun r = p.createRun();
   r.setBold(bold);                                      //加粗
   r.setText(text);
   r.setFontFamily(fontFamily);
   r.setFontSize(fontSize);                                     //字体大小 二号对应21
   return r;
}

4.2.2  四种

 

/**
 * 段落的文本
 * @param p
 * @param text    文本
 * @param fontFamily  字体
 * @param fontSize   字号
 */
public XWPFRun creXR_ptff(XWPFParagraph p, String text,StringfontFamily, int fontSize) {
   XWPFRun r = p.createRun();
   r.setText(text);
   r.setFontFamily(fontFamily);
   r.setFontSize(fontSize);                                     //字体大小 二号对应21
   return r;
} 

4.2.3  三种

/**
 * 段落的文本
 * @param p
 * @param fontFamily   字体
 * @param fontSize   字号
 */
public XWPFRun creXR_pff(XWPFParagraph p,StringfontFamily, int fontSize) {
   XWPFRun r = p.createRun();
   r.setFontFamily(fontFamily);
   r.setFontSize(fontSize);                                     //字体大小 二号对应21
   return r;
}


 

 

 

 



  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
poi-tl是一个基于Apache POI的Java库,用于生成Word文档。它提供了简单易用的API,可以通过编程方式创建和编辑Word文档,包括添加文本、表格、图片、样式等内容。 使用poi-tl生成Word文档的基本步骤如下: 1. 导入poi-tl库:在项目中引入poi-tl的依赖库。 2. 创建Word文档对象:使用`XWPFTemplate`类创建一个空的Word文档对象。 3. 填充数据:通过模板引擎的方式,将数据填充到Word文档中。可以使用Freemarker或Velocity等模板引擎。 4. 导出文档:将填充好数据的Word文档导出为文件或输出流。 以下是一个使用poi-tl生成Word文档的示例代码: ```java // 导入依赖库 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.apache.poi.xwpf.usermodel.XWPFTableCell; import org.apache.poi.xwpf.usermodel.ParagraphAlignment; // 创建一个空的Word文档对象 XWPFDocument document = new XWPFDocument(); // 添加段落 XWPFParagraph paragraph = document.createParagraph(); paragraph.setAlignment(ParagraphAlignment.CENTER); XWPFRun run = paragraph.createRun(); run.setText("Hello, World!"); // 添加表格 XWPFTable table = document.createTable(3, 3); for (int row = 0; row < 3; row++) { XWPFTableRow tableRow = table.getRow(row); for (int col = 0; col < 3; col++) { XWPFTableCell tableCell = tableRow.getCell(col); tableCell.setText("Cell " + (row + 1) + "-" + (col + 1)); } } // 导出文档 FileOutputStream out = new FileOutputStream("output.docx"); document.write(out); out.close(); document.close(); ``` 这是一个简单的示例,你可以根据具体需求使用poi-tl的更多功能来生成复杂的Word文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值