poi-对于word的操作(一)
2017-03-02 15:17:30
使用的jar包是poi 3.13 实现对word的存入,字体、颜色、大小的控制
测试类:
package poi.test; public class WordMain1 {
/**
* 1.对于word,使用XWPFDocument操作07以上的doc或者docx都没有问题,并且必须是07或者以上的电脑上生成的word
* 如果是WordExtractor或者HWPFDocument只能操作03以下的word,并且只能是03以下电脑生成的word
*
* @param args
*/ public static void main(String[] args) {
String path = "e:\\poi\\";
String fileName = "poi.docx";
String filePath = path + fileName;
//创建word
WordUtils1.createWord(path,fileName);
//写入数据
String data = "本文是以poi3.9读写2010word、2010excel、2010ppt,记录学习的脚步相应的功能在代码都有注释,就不解释了 详情可以参看poi3.9的文档主测试函数 TestMain.java";
WordUtils1.writeDataDocx(filePath,data,true,12);
//WordUtils.writeDataDoc(filePath,data); //读取数据
//String contentWord=WordUtils.readDataDoc(filePath);
String contentWord=WordUtils1.readDataDocx(filePath);
System.out.println("word的内容为:\n"+contentWord);
System.out.println();
} }
工具类:
package poi.test; import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import org.apache.poi.xwpf.usermodel.XWPFDocument;
import org.apache.poi.xwpf.usermodel.XWPFParagraph;
import org.apache.poi.xwpf.usermodel.XWPFRun; //创建.doc后缀的word
public class WordUtils1 {
public static void createWord(String path,String fileName){
//判断目录是否存在
File file=new File(path);
//exists()测试此抽象路径名表示的文件或目录是否存在。
//mkdir()创建此抽象路径名指定的目录。
//mkdirs()创建此抽象路径名指定的目录,包括所有必需但不存在的父目录。
if(!file.exists()) file.mkdirs();
//因为HWPFDocument并没有提供公共的构造方法 所以没有办法构造word
//这里使用word2007及以上的XWPFDocument来进行构造word
@SuppressWarnings("resource")
XWPFDocument document=new XWPFDocument();
OutputStream stream=null;
try {
stream = new FileOutputStream(new File(file, fileName));
document.write(stream);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally{
if(stream != null);
try {
stream.close();
} catch (IOException e) {
e.printStackTrace();
}
}
} //向word中写入数据
/**
* 有些方法需要传特殊类型的参数的时候,一般可以用★静态的接口.参数★来传参
* @param path
* @param data
*/
public static void writeDataDocx(String path,String data,boolean jiacu,int size){
InputStream istream=null;
OutputStream ostream=null;
try {
istream = new FileInputStream(path);
ostream = new FileOutputStream(path);
@SuppressWarnings("resource")
XWPFDocument document=new XWPFDocument();
//添加一个段落
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);//--此元素指定是否消费者应中断超过一行的文本范围,通过打破这个词 (打破人物等级) 的两行或通过移动到下一行 (在词汇层面上打破) 这个词的拉丁文字。
XWPFRun r1=p1.createRun();//p1.createRun()将一个新运行追加到这一段
//setText(String value)或
//setText(String value,int pos)
//value - the literal text which shall be displayed in the document
//pos - - position in the text array (NB: 0 based)
r1.setText(data);
//r1.setTextPosition(20);//这个相当于设置行间距的,具体这个20是怎么算的,不清楚,此元素指定文本应为此运行在关系到周围非定位文本的默认基线升降的量。不是真正意义上的行间距
//---This element specifies the amount by which text shall be ★raised or lowered★ for this run in relation to 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设置下划线
//document.createTable(2, 2);//--创建一个制定行列的表
//document.enforceReadonlyProtection();//--强制执行制度保护 /**
* r1.setDocumentbackground(doc, "FDE9D9");//设置页面背景色
r1.testSetUnderLineStyle(doc);//设置下划线样式以及突出显示文本
r1.addNewPage(doc, BreakType.PAGE);
r1.testSetShdStyle(doc);//设置文字底纹
*/
document.write(ostream);
System.out.println("创建word成功");
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally{
if(istream!=null){
try {
istream.close();
} catch (IOException e) {
e.printStackTrace();
}
}
if(ostream!=null){
try {
ostream.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
} //向word中写入数据
// public static void writeDataDoc(String path,String data){
// OutputStream ostream=null;
// try {
// ostream = new FileOutputStream(path);
// ostream.write(data.getBytes());
// } catch (FileNotFoundException e) {
// e.printStackTrace();
// } catch (IOException e) {
// e.printStackTrace();
// }finally{
// if(ostream != null){
// try {
// ostream.close();
// } catch (IOException e) {
// e.printStackTrace();
// }
// }
// }
// } //读取数据 docx
public static String readDataDocx(String filePath) {
String content="";
InputStream istream=null;
try {
istream = new FileInputStream(filePath);
@SuppressWarnings("resource")
XWPFDocument document=new XWPFDocument(istream);
//getLastParagraph()返回包含页眉或页脚的文本的段落
//getText()返回文档所有文本
content=document.getLastParagraph().getText();//★★★★★
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally{
if(istream != null){ }
}
return content;
}
}
poi-对于word的操作(一)的更多相关文章
- poi对word的操作(总结)
★★★ POI在读写word docx文件时是通过xwpf模块来进行的,其核心是XWPFDocument. 1.正文段落:一个文档包含多个段落Paragraph,一个段落包含多个Runs,一个R ...
- 使用POI导出Word(含表格)的实现方式及操作Word的工具类
.personSunflowerP { background: rgba(51, 153, 0, 0.66); border-bottom: 1px solid rgba(0, 102, 0, 1); ...
- Java POI 解析word文档
实现步骤: 1.poi实现word转html 2.模型化解析html 3.html转Map数组 Map数组(数组的操作处理不做说明) 1.导jar包. 2.代码实现 package com.web.o ...
- POI读写Word docx文件
使用POI读写word docx文件 目录 1 读docx文件 1.1 通过XWPFWordExtractor读 1.2 通过XWPFDocument读 2 写docx ...
- POI 读取word (word 2003 和 word 2007) (转)
最近在给客户做系统的时候,用户提出需求,要能够导入 word 文件,现在 microsoft word 有好几个版本 97.2003.2007的,这三个版本存储数据的格式上都有相当大的差别,而现在 9 ...
- POI生成word文档完整案例及讲解
一,网上的API讲解 其实POI的生成Word文档的规则就是先把获取到的数据转成xml格式的数据,然后通过xpath解析表单式的应用取值,判断等等,然后在把取到的值放到word文档中,最后在输出来. ...
- 使用POI读写Word doc文件
使用POI读写word doc文件 目录 1 读word doc文件 1.1 通过WordExtractor读文件 1.2 通过HWPFDocument读文件 2 写w ...
- android使用POI读写word doc文件
目录 1 读word doc文件 1.1 通过WordExtractor读文件 1.2 通过HWPFDocument读文件 2 写word doc文件 Apache p ...
- java工具类POI导出word
1.新建一个word,里面填写内容,如: 2.导出wordjava类 /** * POI导出word测试 * @throws Exception */ @RequestMapping(value=&q ...
- Java利用poi生成word(包含插入图片,动态表格,行合并)
转(小改): Java利用poi生成word(包含插入图片,动态表格,行合并) 2018年12月20日 09:06:51 wjw_11093010 阅读数:70 Java利用poi生成word(包含插 ...
随机推荐
- 面象对象设计原则之一:单一职责原则(Single Responsibility Principle, SRP)
单一职责原则是最简单的面向对象设计原则,它用于控制类的粒度大小.单一职责原则定义如下:单一职责原则(Single Responsibility Principle, SRP):一个类只负责一个功能领域 ...
- 文件系统的block 数据库中的block 以及内存中的page基础知识汇总(自己理解 可能有误)
1. 操作系统文件系统中的的block 文件系统中的block 是文件系统最小的读写单元,在HDD的磁盘时代, 一般block的大小可能与磁盘的扇区大小一致为 512bytes 也因为这个原因MBR启 ...
- children()与find()区别
1.children() 返回被选元素的所有直接子元素,该方法只会向下一级对 DOM 树进行遍历: 2.find() 返回被选元素的后代元素,一路向下直到最后一个后代.
- 通过几个例子看sed的模式空间与保持空间
SED之所以能以行为单位的编辑或修改文本,其原因在于它使用了两个空间:一个是活动的“模式空间(pattern space)”,另一个是起辅助作用的“暂存缓冲区(holdingspace)这2个空间的使 ...
- hive外部表
创建外部表.数据从HDFS获取 只是建立了链接,hdfs中的数据丢失,表中数据也丢失;hdfs数据增加,表中数据也增加 上传文件 创建外部表 删除文件 执行查询语句,发现少了
- php技术–php中感叹号!和双感叹号!!的用法(三元运算)
---恢复内容开始--- if(文章==有用){狂点我;} 在php持术或其他语言中我们经常会看到感叹号的用法,有一定程序语言基础的朋友都知道单个感叹号的作用是取反的意思,也就是取当前结果的反面,如: ...
- jvm学习三:自定义ClassLoader
第一节我们说过一句话:所有的Java虚拟机实现必须在每个类或接口被Java程序“ 首次主动使用”时才初始化他们 但类加载器却不是这样:类加载器不需要等到某个类“被首次主动使用”时才加载类 两句话的区别 ...
- BZOJ3963 WF2011MachineWorks(动态规划+斜率优化+cdq分治)
按卖出时间排序后,设f[i]为买下第i台机器后的当前最大收益,则显然有f[i]=max{f[j]+gj*(di-dj-1)+rj-pi},且若此值<0,应设为-inf以表示无法购买第i台机器. ...
- HDU4403-模拟、数学
一道很难的奥数题,给出一个数字串,插入加号和等号使之成立.求成立的算式数. 我的做法是,先分成两段,中间插入等号 ,再分别求出左右两边可能的值和个数,然后对比,把值相等的情况乘起来,加到最终结果上. ...
- poj3278 【BFS】
Catch That Cow Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 97240 Accepted: 30519 ...