Java如何基于poi操作Wold工具类

Apache封装的POI组件对Excel,Wold的操作已经非常的丰富了,在项目上也会经常用到一些POI的基本操作

这里就简单的阐述POI操作Wold的基本工具类,代码还是有点粗造的,但是不影响使用。

这个类包含了一些对文本进行换行,加粗,倾斜,字体颜色,大小,首行缩进,添加边框等方法。分享给大家学习下:

  • Apache POI的组件:
  • ApachePOI包含用于处理MS-Office的所有OLE2复合文档的类和方法。该API的组件列表如下 -
  • POIFS(不良混淆实现文件系统) - 此组件是所有其他POI元素的基本因素。它用于显式读取不同的文件。
  • HSSF(可怕的SpreadSheet格式) - 用于读取和写入.xls格式的MS-Excel文件。
  • XSSF(XML SpreadSheet格式) - 用于MS-Excel的.xlsx文件格式。
  • HPSF(可怕的属性集格式) - 用于提取MS-Office文件的属性集。
  • HWPF(可怕的字处理器格式) - 用于读写MS-Word的.doc扩展文件。
  • XWPF(XML字处理器格式) - 用于读写MS-Word的.docx扩展文件。
  • HSLF(可怕的幻灯片布局格式) - 用于阅读,创建和编辑PowerPoint演示文稿。
  • HDGF(可怕的DiaGram格式) - 它包含MS-Visio二进制文件的类和方法。
  • HPBF(可怕的PuBlisher格式) - 用于读写MS-Publisher文件。

下面就献上代码:

首先我们引入需要的第三方jar包

<dependency>
  <groupId>org.apache.poi</groupId>
  <artifactId>poi</artifactId>
  <version>3.9</version>
</dependency>
<dependency>
  <groupId>org.apache.poi</groupId>
  <artifactId>poi-ooxml</artifactId>
  <version>3.9</version>
</dependency>

工具类具体代码:

package com.herbert.test;

import org.apache.poi.xwpf.usermodel.*;
import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTFonts;
import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTRPr;

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

/**
* Created by Herbert on 2019/1/22.
*/
public class WoldUtil {
 private static XWPFDocument document = null;

  private static XWPFParagraph paragraph = null;

  /**
  * 初始化创建Word文件
  */
  public WoldUtil(){
    document = new XWPFDocument();
  }

  /**
  * 创建一个段落
  * @param position 段落位置
  *         0:居左
  *         1:居中
  *         2:居右
  */
  public void createParagraph(Integer position){
    paragraph = document.createParagraph();
    switch (position){
      case 0:
        paragraph.setAlignment(ParagraphAlignment.LEFT);
        break;
      case 1:
        paragraph.setAlignment(ParagraphAlignment.CENTER);
        break;
      case 2:
        paragraph.setAlignment(ParagraphAlignment.RIGHT);
        break;
      default:
        paragraph.setAlignment(ParagraphAlignment.LEFT);
        break;
    }
  }

  /**
  * 单线边框
  */
  public void createBorder(){

    paragraph.setBorderTop(Borders.THICK);//设置上边框
    paragraph.setBorderBottom(Borders.THICK);//设置下边框
    paragraph.setBorderLeft(Borders.THICK);//设置左边框
    paragraph.setBorderRight(Borders.THICK);//设置右边框
  }

  /**
  * 双线边框
  */
  public void createBorderDouble(){
    paragraph.setBorderTop(Borders.DOUBLE);//设置上边框
    paragraph.setBorderBottom(Borders.DOUBLE);//设置下边框
    paragraph.setBorderLeft(Borders.DOUBLE);//设置左边框
    paragraph.setBorderRight(Borders.DOUBLE);//设置右边框
  }

  /**
  * 首行缩进
  * @param indentation
  */
  public void addTextIndent(Integer indentation){
    paragraph.setIndentationFirstLine(indentation);
  }

  /**
  * 创建文本信息
  * @param text 文本信息
  * @param bold 是否加粗 true为加粗
  * @param italic 是否倾斜 true为倾斜
  * @param color 颜色码
  * @param fontSize 字体大小
  * @param fontFamily 设置字体
  */
  public void createRun(String text, Boolean bold,Boolean italic, String color,Integer fontSize,String fontFamily){
    XWPFRun r = paragraph.createRun();//创建段落文本
    r.setText(text);
    r.setBold(bold);//设置为粗体 true 为粗体
    r.setItalic(italic);//设置为倾斜 true 为粗体
    r.setColor(color);//设置颜色
    r.setFontSize(fontSize);
    CTRPr rpr = r.getCTR().isSetRPr() ? r.getCTR().getRPr() : r.getCTR().addNewRPr();
    CTFonts fonts = rpr.isSetRFonts() ? rpr.getRFonts() : rpr.addNewRFonts();
    fonts.setAscii(fontFamily);
    fonts.setEastAsia(fontFamily);
    fonts.setHAnsi(fontFamily);

  }

  /**
  * 写到磁盘
  * @param path
  */
  public void write(String path){
    try{
      FileOutputStream out = new FileOutputStream(path);
      document.write(out);
      out.close();
    }catch (IOException e){
      e.printStackTrace();
      System.out.println("文件出现错误");
    }

  }

  /**
  * 创建空行
  * @param counts 空行个数
  */
  public void createEmpty(Integer counts){
    for(int i =0;i<counts;i++){
      XWPFParagraph empty = document.createParagraph();
      XWPFRun e = empty.createRun();
      e.setText(" ");
    }
  }

  /**
  * 查询wold中的数据 返回List 集合
  * @param path wold所在的地址
  * @return
  */
  public List<String> query(String path){
    List<String> list = new ArrayList<String>();
    try{
      FileInputStream stream = new FileInputStream(path);
      XWPFDocument doc = new XWPFDocument(stream);// 创建Word文件
      for(XWPFParagraph p : doc.getParagraphs()){//遍历段落
        System.out.println(p.getParagraphText());
        list.add(p.getParagraphText());
      }
    }catch (Exception e){
      e.printStackTrace();
    }
    return list;
  }
  public static void main(String args[]) throws Exception {
    WoldUtil woldUtil = new WoldUtil();
    woldUtil.createParagraph(1);
    woldUtil.createBorder();
    woldUtil.createRun("(标题居中)Apache POI的组件", true, false,"000000",17,FontFamily.BLACKBODY);
    woldUtil.createBorderDouble();

    woldUtil.createParagraph(0);
    woldUtil.createRun("(边框)Apache POI包含用于处理MS-Office的所有OLE2复合文档的类和方法。该API的组件列表如下:", false,true, "4682B4",15,FontFamily.CHINESE_FINE_BLACK);

    woldUtil.createEmpty(3);

    woldUtil.createParagraph(0);
    woldUtil.addTextIndent(600);
    woldUtil.createRun("(首行缩进)• POIFS(不良混淆实现文件系统) - 此组件是所有其他POI元素的基本因素。它用于显式读取不同的文件", true,false,"A0522D",13,FontFamily.MICROSOFT_YAHEI);

    woldUtil.createEmpty(1);

    woldUtil.createParagraph(0);
    woldUtil.createRun("•HWPF(可怕的字处理器格式) - 用于读写MS-Word的.doc扩展文件。", true,false,"eeff00",13,FontFamily.MICROSOFT_YAHEI);

    woldUtil.write("E:\\herbert\\sample.doc");

    List<String> list =woldUtil.query("E:\\herbert\\sample.doc");
    System.out.println("list=====>>>>>>>>  "+list.toString());
  }
}

测试截图

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

(0)

相关推荐

  • java poi sax方式处理大数据量excel文件

    系统需要用到一个导入excel文件的功能,使用poi组件常规方式读取excel时,内存耗尽,OutOfMemoryError,或者读取非常慢 所以写了一个工具类,使用poi sax方式读取excel,速度快很多,内存消耗可以接受. 测试结果如下: .xlsx文件,35M大小,总4个sheel, 只读取第一个,37434行,54列 总行数:37434 读取耗时:39秒 打印耗时:17秒 主要代码如下: ExcelUtils.class 主入口 package com.xxx.bi.utils.ex

  • Java如何利用POI读取Excel行数

    这篇文章主要介绍了java如何利用POI读取Execel行数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 java 利用poi 读excel文件的操作,读取总的数据行数一般是通过调用 sheet.getLastRowNum() ;可是这样有时候会出现一些问题,例如,当其中一行的数据的确都为空,可是其原本的格式还在,并没有连带删除,这样计算出来的行数就不真实(比真实的大),还有当出现空白行时(也即某一行没有任何数据,通过Row row = sh

  • Java使用poi组件导出Excel格式数据

    在做管理系统的时候,我想Excel的导出是我们很难规避掉的,而且这也是个很实用很人性化的功能. Java中对于Excel的支持有很多种,比如说JXL,POI等.我这边使用的是POI进行一个Excel的操作,下面我会简单分享下POI组件的使用,以及我使用比较多一个工具类. POI组件 poi组件是由Apache提供的组件包,主要职责是为我们的Java程序提供对于office文档的相关操作.本文主要是它对于Excel操作的一个介绍. 官方主页:http://poi.apache.org/index.

  • java.lang.NullPointerException 如何处理空指针异常的实现

    当应用程序试图null在需要对象的情况下使用时抛出.这些包括: 调用null对象的实例方法. 访问或修改null对象的字段. 把长度null当作一个数组. 像访问或修改null阵列一样访问或修改插槽. 投掷null就好像它是一个Throwable 价值. 应用程序应该抛出此类的实例来指示null对象的其他非法使用. NullPointerException对象可以由虚拟机构造,就像抑制被禁用和/或堆栈跟踪不可写一样. 为什么我们需要空值? 如前所述,nullJava是一种特殊的值. 它在编码某些

  • Java使用POI导出大数据量Excel的方法

    今天需要写一个导出的Excel的功能,但是发现当数据量到3万条时,列数在23列时,内存溢出,CPU使用100%,测试环境直接炸掉.在本地测试时发现,导出3000条左右的数据的时候,堆内存瞬间升高500M左右.然后发现了 SXSSFWorkbook 这个类. 简介 SXSSFWorkbook 需要 poi-ooxml 包 3.8 及以上开始支持,我这边适使用的是 3.9 版本,本质是一个 XSSFWorkbook 类( Excel2007 ),它使用的方式是采用 硬盘空间 来大幅降低 堆内存 的占

  • java基于poi导出excel透视表代码实例

    这篇文章主要介绍了java基于poi导出excel透视表代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 从前,我是一个前端程序猿,怀着对打通任(前)督(后)二(开)脉(发)的梦想转了后端,自学两礼拜java+spring全家桶,直接上项目实战.最近接到一需求:将业务数据导出一张透视表. 需求开发完成已近有一段时间了,甲方的大爷大妈,爷爷奶奶们也都用的很开心,我也很开心,于是就心想咱学了也不能白学,所以写下这篇随笔. 先看下用easypo

  • java使用poi读取doc和docx文件的实现示例

    这几天在学习java io流的东西,有一个网友看到博客后问了一个问题,就是说他的doc文档为什么用我所说的方法死活就是乱码. 我一开始以为是他方法问题,结果自己试了之后发现和他的结果一样也是乱码. 于是在网上搜寻了一阵之后才发现原来doc文档和excel一样不能用普通的io流的方法来读取,而是也需要用poi,于是进行了一番尝试后,终于以正确的编码格式读取了这个doc文件. 在网上搜索的过程中发现doc和docx的读取方法是不一样的,于是顺带也学了一下docx文件的简单读取. 一.导包: doc文

  • Java如何基于poi操作Wold工具类

    Apache封装的POI组件对Excel,Wold的操作已经非常的丰富了,在项目上也会经常用到一些POI的基本操作 这里就简单的阐述POI操作Wold的基本工具类,代码还是有点粗造的,但是不影响使用. 这个类包含了一些对文本进行换行,加粗,倾斜,字体颜色,大小,首行缩进,添加边框等方法.分享给大家学习下: Apache POI的组件: ApachePOI包含用于处理MS-Office的所有OLE2复合文档的类和方法.该API的组件列表如下 - POIFS(不良混淆实现文件系统) - 此组件是所有

  • Java操作XML工具类XmlUtil详解

    本文实例为大家分享了Java操作XML工具类的具体代码,供大家参考,具体内容如下 一.代码 public class XmlUtil { /** * 将XML文件输出到指定的路径 * * @param doc * @param fileName * @throws Exception */ public static void outputXml(Document doc, String fileName) throws Exception { TransformerFactory tf = T

  • Java操作集合工具类Collections使用详解

    这篇文章主要介绍了java操作集合工具类Collections使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 Collections是一个操作Set.List和Map等集合的工具类. Collections中提供了大量方法对集合元素进行排序.查询和修改等操作,还提供了对集合对象设置不可变.对集合对象实现同步控制等方法. 排序操作: reverse(List):反转List中元素的顺序: shuffle(List):对List集合元素进行

  • Java实现的3des加密解密工具类示例

    本文实例讲述了Java实现的3des加密解密工具类.分享给大家供大家参考,具体如下: package com.gcloud.common; import org.apache.poi.poifs.property.Child; import org.bouncycastle.jce.provider.BouncyCastleProvider; import javax.crypto.*; import javax.crypto.spec.IvParameterSpec; import javax

  • Java实现的微信图片处理工具类【裁剪,合并,等比例缩放等】

    本文实例讲述了Java实现的微信图片处理工具类.分享给大家供大家参考,具体如下: 现在 外面核心,图片文章比较少,看了拷贝代码,而用不了,用相应jar包处理,很多等比例缩放,达不到 想要的给予的期望:本工具类,是之前做微信打印机写的 基于java自带的类,基于rgb. package com.zjpz.util; import java.awt.Color; import java.awt.Graphics; import java.awt.Graphics2D; import java.awt

  • Java实现的图片上传工具类完整实例

    本文实例讲述了Java实现的图片上传工具类.分享给大家供大家参考,具体如下: package com.gcloud.common; import javax.imageio.ImageIO; import java.awt.image.BufferedImage; import java.io.*; /** * 图片上传工具类 * Created by charlin on 2017/9/10. */ public class UploadImageUtil { private String f

  • Java实现的DES加密解密工具类实例

    本文实例讲述了Java实现的DES加密解密工具类.分享给大家供大家参考,具体如下: 一个工具类,很常用,不做深入研究了,那来可直接用 DesUtil.java package lsy; import java.security.Key; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; imp

  • Java实现的读取资源文件工具类ResourcesUtil实例【可动态更改值的内容】

    本文实例讲述了Java实现的读取资源文件工具类ResourcesUtil.分享给大家供大家参考,具体如下: package com.gcloud.common; import java.io.Serializable; import java.text.MessageFormat; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import java.util.Locale; impor

  • Java实现的执行python脚本工具类示例【使用jython.jar】

    本文实例讲述了Java实现的执行python脚本工具类.分享给大家供大家参考,具体如下: 这里java中执行python脚本工具类,需要使用jython.jar java中执行python脚本工具类,学习的时候写着玩: import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.util.ArrayList; import java.util.List; i

  • java实现的日期时间转换工具类完整示例

    本文实例讲述了java实现的日期时间转换工具类.分享给大家供大家参考,具体如下: 最基础的东西,总结一下,下次用的时候就方便一些了.废话不多说,直接贴代码: package com.incar.base.util; import com.incar.base.exception.BaseRuntimeException; import java.text.DateFormat; import java.text.ParseException; import java.text.SimpleDat

随机推荐