Apache POI PPT - 快速指南

2018-12-27 16:15 更新

Apache POI PPT - 概述

很多时候,需要一个软件应用程序来生成Microsoft Office文件格式的报告。 有时,应用程序甚至希望接收MS- Office文件作为输入数据。

任何希望生成MS Office文件作为输出的Java程序员都必须使用预定义和只读API来执行此操作。

什么是Apache POI?

Apache POI是一个流行的API,允许程序员使用Java程序创建,修改和显示MS-Office文件。 它是由Apache Software Foundation开发和发布的一个开源库。 它包含用于解码用户输入数据或将文件转换为MS Office文档的类和方法。

Apache POI的组件

Apache POI包含用于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(Horrible DiaGram格式):它包含MS-Visio二进制文件的类和方法。

  • HPBF(Horrible PuBlisher格式):用于读取和写入MS-Publisher文件。

本教程将指导您完成使用Java进行Microsoft PowerPoint演示文稿的过程。 因此,讨论限于 XSLF组件。

注意:旧版本的POI支持二进制文件格式,如doc,xls,ppt等。版本3.5起,POI支持MS- Office的OOXML文件格式,如docx,xlsx,pptx等。

Java PPT API的口味

本章将介绍Java PowerPoint API及其功能的一些风格。 有许多供应商提供Java PPT相关的API; 其中一些在本章中考虑。

Aspose Slides for Java

用于Java的Aspose幻灯片是一个纯许可的Java PPT API,由供应商 Aspose 开发和发布。 这个API的最新版本是8.1.2,于2014年7月发布。它是一个丰富而重的API(纯Java类和AWT类的组合),用于设计可以读取,写入和管理幻灯片的PPT组件。

此API的常见用途如下:

  • Build dynamic presentations
  • Render and print high-fidelity presentations
  • Generate, edit, convert, and print presentations

Apache POI

Apache POI是Apache Software Foundation提供的一个100%开源库。 大多数中小型应用程序开发人员严重依赖Apache POI(HSLF + XSLF)。 它支持PPT库的所有基本功能; 然而,渲染和文本提取是其主要特征。 下面给出了用于PPT的Apache POI的架构。

Apache POI PPT - 安装

本章将介绍在基于Windows和Linux的系统上设置Apache POI的过程。 Apache POI可以轻松地安装并与您当前的Java环境集成,遵循几个简单的步骤,没有任何复杂的设置过程。 安装需要用户管理。

系统要求

JDKJava SE 2 JDK 1.5或更高版本
内存1 GB RAM(推荐)
磁盘空间无最低要求
操作系统版本Windows XP或以上版本,Linux

现在让我们继续安装Apache POI的步骤。

步骤1:验证Java安装

首先,您需要在系统上安装Java软件开发工具包(SDK)。 要验证此,请根据您正在处理的平台执行以下两个命令。

如果Java安装已正确完成,那么它将显示Java安装的当前版本和规范。 下表给出了样本输出。

平台命令示例输出
Windows

打开命令控制台并键入:

\> java -version

Java版本“1.7.0_60"

Java TM SE运行时间

环境(build 1.7.0_60-b19)

Java Hotspot(TM)64位服务器

VM(构建24.60-b09,混合模式)

Linux

打开命令终端并键入:

$ java -version

java版本“1.7.0_25"

打开JDK运行时环境(rhel-2.3.10.4.el6_4-x86_64)

打开JDK 64位服务器虚拟机(构建23.7-b01,混合模式)

步骤2:设置Java环境

将环境变量JAVA_HOME设置为指向计算机上安装Java的基本目录位置。 例如,

平台描述
Windows将JAVA_HOME设置为 C:\ProgramFiles\java\jdk1.7.0_60
Linux导出JAVA_HOME = / usr / local / java-current

将Java编译器位置的完整路径附加到系统路径。

描述描述
Windows将字符串"C:\Program Files\Java\jdk1.7.0_60\bin"附加到系统变量PATH的结尾。
Linux导出PATH = $ PATH:$ JAVA_HOME / bin /

如上所述,从命令提示符处执行命令 java -version

步骤3:安装Apache POI库

http://poi.apache.org/download 下载最新版本的Apache POI。 html ,并将其内容解压缩到一个文件夹,从中可以将所需的库链接到Java程序。 让我们假设文件收集在C驱动器上的文件夹中。

以下图像显示已下载文件夹中的目录和文件结构:

将上述图片中突出显示的五个 jars 的完整路径添加到CLASSPATH。

描述描述
Windows

将以下字符串附加到用户变量CLASSPATH的结尾:

“C:\poi-3.9\poi-3.9-20121203.jar;"

“C:\poi-3.9\poi-ooxml-3.9-20121203.jar;"

“C:\poi-3.9\poi-ooxml-schemas-3.9-20121203.jar;"

“C:\poi-3.9\ooxml-lib\dom4j-1.6.1.jar;"

“C:\poi-3.9\ooxml-lib\xmlbeans-2.3.0.jar;.;"

Linux

导出CLASSPATH = $ CLASSPATH:

/usr/share/poi-3.9/poi-3.9-20121203.tar:

/usr/share/poi-3.9/poi-ooxml-schemas-3.9-20121203.tar:

/usr/share/poi-3.9/poi-ooxml-3.9-20121203.tar:

/usr/share/poi-3.9/ooxml-lib/dom4j-1.6.1.tar:

/usr/share/poi-3.9/ooxml-lib/xmlbeans-2.3.0.tar

Apache POI PPT - 类和方法

在本章中,我们将了解Apache POI API下的几个类和方法,这些对于使用Java程序处理PPT文件至关重要。

介绍

要创建和管理演示文稿,您在包 org.apache.poi.xslf.usermodel 中有一个名为XMLSlideShow的类。 下面给出了一些重要的方法和这个类的构造函数。

:XMLSlideShow

:org.apache.poi.xslf.usermodel

S.No构造函数和说明
1

XMLSlideShow(java.io.InputStream inputStream)

你可以通过传递一个inputstream类对象来实例化这个类。

S.No方法和描述
1

int addPicture(byte [] pictureData,int format)

使用此方法,您可以向演示文稿添加图片。

2

XSLFSlide createSlide()

在演示文稿中创建空白幻灯片。

3

XSLFSlide createSlide(XSLFSlideLayout布局)

创建具有给定幻灯片布局的幻灯片。

4

java.util.List< XSLFPictureData> getAllPictures()

返回一个演示文稿中所有图片的数组。

5

java.awt.Dimension getPageSize()

使用此方法,您可以了解当前页面大小。

6

XSLFSlideMaster [] getSlideMasters()

返回演示文稿中所有幻灯片的数组。

7

XSLFSlide [] getSlides()

返回演示文稿中的所有幻灯片。

8

XslFSlide removeSlide(int index)

使用此方法,您可以从演示文稿中删除幻灯片。

9

void setPageSize(java.awt.Dimension pgSize)

使用此方法,您可以重置页面大小。

10

void setSlideOrder(XSLFSlide slide,int newIndex)

使用此方法,您可以重新排序幻灯片。

滑动

要在演示文稿中创建和管理幻灯片,请使用 XSLFSlide 类的方法。 这一类的一些重要方法如下所述。

:XSLFSlide

套件:org.apache.poi.xslf.usermodel

S.No方法和描述
1

XSLFBackground getBackground()

返回 XSLFBackground 对象,可用于检索幻灯片背景的颜色和锚点等详细信息。 您还可以使用此对象在幻灯片中绘制形状。

2

XSLFSlideLayout getSlideLayout()

提供对当前幻灯片的 XSLFSlideLayout 对象的访问。

3

XSLFSlideMaster getSlideMaster()

提供对当前幻灯片的幻灯片母版的访问。

4

XSLFTheme getTheme()

返回当前幻灯片的 XSLFTheme 对象。

5

java.lang.String getTitle()

返回当前幻灯片的标题。

6

XSLFSlide importContent(XSLFSheet src)

将另一张幻灯片的内容复制到此幻灯片。

幻灯片母版

它是演示文稿的组件具有不同的幻灯片布局。 XSLFSlideMaster 类可让您访问它。 下面提到这个类的一些重要方法。

:XSLFSlideMaster

套件:org.apache.poi.xslf.usermodel

S.No描述
1

XSLFBackground getBackground()

返回幻灯片母版的常用背景。

2

XSLFSlideLayout getLayout(SlideLayout type)

返回XSLFSlideLayout对象。

3

XSLFSlideLayout [] getSlideLayouts()

返回此幻灯片母版中的所有幻灯片布局。

幻灯片布局

POI库有一个名为 XSLFSlideLayout 的类,您可以使用它来管理幻灯片的布局。

:XSLFSlideLayout

套件:org.apache.poi.xslf.usermodel

描述方法和说明
1

void copyLayout(XSLFSlide幻灯片)

此方法会将占位符从此布局复制到给定幻灯片。

文本段落

您可以使用 XSLFTextParagraph 类别将内容写入幻灯片。 下面提到这个类的一些重要方法。

:XSLFTextParagraph

套件:org.apache.poi.xslf.usermodel

S.No方法和描述
1

XSLFTextRun addLineBreak()

在段落中插入换行符。

2

XSLFTextRun addNewTextRun()

在段落中添加新的文本行。

3

void setBulletAutoNumber(ListAutoNumber scheme,int startAt)

将自动编号的项目符号点应用于段落。

4

void setIndent(double value)

将缩进设置为段落中的文本。

5

void setLeftMargin(double value)

此方法用于添加段落的左边距。

6

void setLineSpacing(double line spacing)

此方法用于在段落中设置行间距。

7

void setTextAlign(TextAlign align)

此方法用于设置要设置为段落的对齐方式。

文本运行

这是文本正文中文本分隔的最低级别。 您可以使用 XSLFTextRun 类来管理段落的文本运行。 下面提到这个类的一些重要方法。

:XSLFTextParagraph

套件:org.apache.poi.xslf.usermodel

S.No方法和描述
1

XSLFHyperlink createHyperlink()

在演示文稿中创建超链接。

2

XSLFHyperlink getHyperlink()

此方法用于获取超链接。

3

java.lang.String getText()

以Java字符串形式返回此Text节点的值。

4

void setBold(boolean bold)

此方法用于以粗体设置文本。

5

void setCharacterSpacing(double spc)

设置文本运行中的字符之间的间距。

6

void setFontColor(java.awt.Color color)

设置文本的字体颜色。

7

void setFontSize(double fontSize)

设置文本的字体大小。

8

void setItalic(boolean italic)

这个方法用于使段落斜体。

9

void setStrikethrough(boolean strike)

此方法用于将一段文本格式化为删除线文本。

10

void setSubscript(boolean flag)

此方法用于将文本格式化为下标。

11

void setSuperscript(boolean flag)

此方法用于将此运行中的文本格式化为上标。

12

void setText(java.lang.String text)

此方法用于在运行中设置文本。

13

void setUnderline(Boolean underline)

此方法用于在文本运行中对文本加下划线。

文本形状

在PPT中,我们有可以在其中保存文本的形状。 我们可以使用 XSLFTextShape 类来管理这些。 下面提到这个类的一些重要方法。

:XSLFTextShape

套件:org.apache.poi.xslf.usermodel

S.No方法和描述
1

void setPlaceholder(Placeholder placeholder)

使用此方法,您可以选择占位符。

2

Placeholder getTextType()

返回当前占位符的类型。

3

void clearText()

清除当前文本形状的文本区域。

4

XSLFTextParagraph addNewTextParagraph()

向形状添加新的段落运行。

5

void drawContent(java.awt.Graphics2D graphics)

此方法允许您在幻灯片上绘制任何内容。

超链接

POI库具有一个名为 XSLFHyperlink 的类,您可以使用它在演示文稿中创建一个超链接。 下面提到这个类的一些重要方法。

:XSLFHyperlink

套件:org.apache.poi.xslf.usermodel

S.No方法和描述
1

java.net.URI getTargetURL()

返回演示文稿幻灯片中存在的网址。

2

void setAddress(java.lang.String address)

此方法用于将地址设置为URL。

3

void setAddress(XSLFSlide幻灯片)

将地址设置为演示文稿幻灯片中显示的网址。

Apache POI PPT - 演示

一般来说,我们使用MS-PowerPoint来创建演示文稿。 现在让我们看看如何使用Java创建演示文稿。 完成本章后,您将能够创建新的MS-PowerPoint演示文稿,并使用您的Java程序打开现有的PPT。

创建空的演示文稿

要创建空的演示文稿,您必须实例化 org.poi.xslf.usermodel 包的 XMLSlideShow 类:

XMLSlideShow ppt = new XMLSlideShow();

使用 FileOutputStream 类将更改保存到PPT文档:

File file=new File("C://POIPPT//Examples//example1.pptx");
FileOutputStream out = new FileOutputStream(file);
ppt.write(out);

以下是创建空白MS-PowerPoint演示文稿的完整程序。

import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class CreatePresentation {
   
   public static void main(String args[]) throws IOException{
   
      //creating a new empty slide show
      XMLSlideShow ppt = new XMLSlideShow();	     
      
      //creating an FileOutputStream object
      File file =new File("example1.pptx");
      FileOutputStream out = new FileOutputStream(file);
      
      //saving the changes to a file
      ppt.write(out);
      System.out.println("Presentation created successfully");
      out.close()
   }
}

将上面的Java代码保存为 CreatePresentation.java ,然后从命令提示符处编译并执行它,如下所示:

$javac  CreatePresentation.java
$java CreatePresentation

如果您的系统环境配置有POI库,它将编译并执行,以在当前目录中生成名为 example1.pptx 的空白PPT文件,并在命令提示符下显示以下输出:

Presentation created successfully

空白PowerPoint文档显示如下:

编辑现有演示文稿

要打开现有的演示文稿,请实例化 XMLSlideShow 类,并将要编辑的文件的 FileInputStream 对象作为 XMLSlideShow 构造函数的参数传递

File file=new File(“C://POIPPT//Examples//example1.pptx");
FileInputstream inputstream =new FileInputStream(file);
XMLSlideShow ppt = new XMLSlideShow(inputstream);

您可以使用 org.poi.xslf.usermodel 包中的XMLSlideShow类的 createSlide()方法将幻灯片添加到演示文稿。

XSLFSlide slide1= ppt.createSlide();

下面给出了打开和添加幻灯片到现有PPT的完整程序:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class EditPresentation {

   public static void main(String ar[]) throws IOException{
	   
      //opening an existing slide show
      File file = new File("example1.pptx");
      FileInputStream inputstream=new FileInputStream(file);
      XMLSlideShow ppt = new XMLSlideShow(inputstream);
      
      //adding slides to the slodeshow
      XSLFSlide slide1 = ppt.createSlide();
      XSLFSlide slide2 = ppt.createSlide();
      
      //saving the changes 
      FileOutputStream out = new FileOutputStream(file);
      ppt.write(out);
      System.out.println("Presentation edited successfully");
      out.close();	
   }
} 

将上述Java代码另存为 EditPresentation.java ,然后从命令提示符处编译并执行,如下所示:

$javac  EditPresentation.java
$java EditPresentation

它将编译并执行以生成以下输出:

slides successfully added

带有新添加的幻灯片的输出PPT文档如下所示:

将幻灯片添加到PPT后,您可以在幻灯片上添加,执行,读取和写入操作。

Apache POI PPT - 幻灯片布局

在上一章中,您已经了解了如何创建空白幻灯片以及如何向其添加幻灯片。 在本章中,您将学习如何获取可用幻灯片的列表,以及如何创建具有不同布局的幻灯片。

可用的幻灯片布局

PowerPoint演示文稿具有幻灯片布局,您可以选择所需的布局来编辑幻灯片。 首先,让我们找出所有可用的幻灯片布局的列表。

  • 有不同的幻灯片母版,在每个幻灯片母版中,有几个幻灯片布局。

  • 您可以使用 XMLSlideShow 类的 getSlideMasters()方法获取幻灯片主题列表。

  • 您可以使用 XSLFSlideMaster 类的 getSlideLayouts()方法从每个幻灯片母带获取幻灯片布局的列表。

  • 您可以使用 XSLFSlideLayout 类的 getType()方法从布局对象获取幻灯片布局的名称。

注意:所有这些类都属于 org.poi.xslf.usermodel 包。

下面给出的是获取PPT中可用幻灯片布局列表的完整程序:

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlideLayout;
import org.apache.poi.xslf.usermodel.XSLFSlideMaster;
public class SlideLayouts {
   public static void main(String args[]) throws IOException{
   
	   //create an empty presentation
      XMLSlideShow ppt = new XMLSlideShow();
      System.out.println("Available slide layouts:")
   
      //getting the list of all slide masters
      for(XSLFSlideMaster master : ppt.getSlideMasters()){
   
         //getting the list of the layouts in each slide master
         for(XSLFSlideLayout layout : master.getSlideLayouts()){
   
            //getting the list of available slides
            System.out.println(layout.getType());
         } 
      }
   }
}

将上述Java代码保存为 SlideLayouts.java ,然后从命令提示符处编译并执行,如下所示:

$javac  SlideLayouts.java
$java SlideLayouts

它将编译并执行以生成以下输出:

Available slide layouts:
TITLE
PIC_TX
VERT_TX
TWO_TX_TWO_OBJ
BLANK
VERT_TITLE_AND_TX
TITLE_AND_CONTENT
TITLE_ONLY
SECTION_HEADER
TWO_OBJ
OBJ_TX

下面显示的是MS-Office 360,2013版本提供的一些示例幻灯片布局。

标题布局

让我们使用标题布局在PPT中创建幻灯片。 请按照以下步骤操作:

步骤1 :通过实例化 XMLSlideShow 类创建一个空的演示文稿,如下所示:

XMLSlideShow ppt = new XMLSlideShow();

步骤2 :使用 getSlideMasters()方法获取幻灯片主题列表。 此后,使用索引选择所需的幻灯片母带,如下所示:

XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];

这里我们得到的默认幻灯片母版是在幻灯片主数据的第0位置。

步骤3 :使用 XSLFSlideMaster 类的 getLayout()方法获取所需的布局。 此方法接受一个参数,您必须传递 SlideLayoutclass 的静态变量之一,代表我们所需的布局。 这个类中有几个变量,每个变量代表一个幻灯片布局。

下面的代码片段显示了如何创建标题布局:

XSLFSlideLayout titleLayout = slideMaster.getLayout(SlideLayout.TITLE);

步骤4 :通过将幻灯片布局对象作为参数传递来创建新幻灯片。

XSLFSlide slide = ppt.createSlide(titleLayout);

第5步:使用 XSLFSlide 类的 getPlaceholder()方法选择占位符。 此方法接受整数参数。 通过传递0到它,你会得到 XSLFTextShape 对象,使用它可以访问幻灯片的标题文本区域。 使用setText()方法设置标题,如下所示:

XSLFTextShape title1 = slide.getPlaceholder(0);
//setting the title init
title1.setText("Tutorials point");

下面给出的是在演示文稿中创建带有标题布局的幻灯片的完整程序:

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.SlideLayout;
import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;
import org.apache.poi.xslf.usermodel.XSLFSlideLayout;
import org.apache.poi.xslf.usermodel.XSLFSlideMaster;
import org.apache.poi.xslf.usermodel.XSLFTextShape;

public class TitleLayout {

   public static void main(String args[]) throws IOException{
   
      //creating presentation
      XMLSlideShow ppt = new XMLSlideShow();	    	
      
      //getting the slide master object
      XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];
      
      //get the desired slide layout 
      XSLFSlideLayout titleLayout = slideMaster.getLayout(SlideLayout.TITLE);
                                                     
      //creating a slide with title layout
      XSLFSlide slide1 = ppt.createSlide(titleLayout);
      
      //selecting the place holder in it 
      XSLFTextShape title1 = slide1.getPlaceholder(0); 
      
      //setting the title init 
      title1.setText("Tutorials point");
      
      //create a file object
      File file=new File("C://POIPPT//Examples//Titlelayout.pptx");
      FileOutputStream out = new FileOutputStream(file);
      
      //save the changes in a PPt document
      ppt.write(out);
      System.out.println("slide cretated successfully");
      out.close();  
   }
}

将上面的Java代码保存为TitleLayout.java,然后从命令提示符处编译并执行它,如下所示:

$javac  TitleLayout.java
$java TitleLayout

它将编译并执行以生成以下输出。

slide created successfully

带有新添加的标题布局幻灯片的PPT文档如下所示:

标题和内容布局

让我们使用标题和内容布局在PPT中创建幻灯片。 按照下面给出的步骤。

步骤1 :通过实例化 XMLSlideShow 类创建一个空的演示文稿,如下所示:

XMLSlideShow ppt = new XMLSlideShow();

步骤2 :使用 getSlideMasters()方法获取幻灯片主题列表。 使用索引选择所需的幻灯片母带,如下所示:

XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];

这里我们得到的默认幻灯片母版是在幻灯片主数据的第0位置。

步骤3 :使用 XSLFSlideMaster 类的 getLayout()方法获取所需的布局。 此方法接受一个参数,您必须传递代表我们所需布局的 SlideLayout 类的静态变量之一。 这个类中有几个变量代表幻灯片布局。

以下代码段显示如何创建标题和内容布局:

XSLFSlideLayout contentlayout = slideMaster.getLayout(SlideLayout.TITLE_AND_CONTENT);

步骤4 :通过将幻灯片布局对象作为参数传递来创建新幻灯片。

XSLFSlide slide = ppt.createSlide(SlideLayout.TITLE_AND_CONTENT);

第5步:使用 XSLFSlide 类的 getPlaceholder()方法选择占位符。 此方法接受整数参数。 通过传递1给它,你会得到 XSLFTextShape 对象,使用它可以访问幻灯片的内容区域。 使用setText()方法设置标题,如下所示:

XSLFTextShape title1 = slide1.getPlaceholder(1);
//setting the title init 
title1.setText("Introduction");

步骤6 :使用 XSLFTextShape 类别的 clearText()方法清除投影片中现有的文字。

body.clearText();

步骤7 :使用 addNewTextParagraph()方法添加新段落。 现在使用 addNewTextRun()方法向段落中添加一个新的文本运行。 现在到文本运行,使用 setText()方法添加文本,如下所示:

body.addNewTextParagraph().addNewTextRun().setText("this is  my first slide body");

下面给出的是在演示文稿中创建带有标题布局的幻灯片的完整程序:

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.SlideLayout;
import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;
import org.apache.poi.xslf.usermodel.XSLFSlideLayout;
import org.apache.poi.xslf.usermodel.XSLFSlideMaster;
import org.apache.poi.xslf.usermodel.XSLFTextShape;

public class TitleAndBodyLayout {
   
   public static void main(String args[]) throws IOException{
   
      //creating presentation
      XMLSlideShow ppt = new XMLSlideShow();
      
      //getting the slide master object
      XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];
      
      //select a layout from specified list
      XSLFSlideLayout slidelayout = slideMaster.getLayout(SlideLayout.TITLE_AND_CONTENT);      
      
      //creating a slide with title and content layout
      XSLFSlide slide = ppt.createSlide(slidelayout);
      //selection of title place holder
      XSLFTextShape title = slide.getPlaceholder(0);
      
      //setting the title in it
      title.setText("introduction");
      
      //selection of body placeholder
      XSLFTextShape body = slide.getPlaceholder(1);
      
      //clear the existing text in the slide
      body.clearText();
      
      //adding new paragraph
      body.addNewTextParagraph().addNewTextRun().setText("this is  my first slide body");
      
      //create a file object
      File file=new File("contentlayout.pptx");
      FileOutputStream out = new FileOutputStream(file);
      
      //save the changes in a file
      ppt.write(out);
      System.out.println("slide cretated successfully");
      out.close();                
   }
}

将上述Java代码保存为 TitleLayout.java ,然后从命令提示符处编译并执行它,如下所示:

$javac  TitleLayout.java
$java TitleLayout

它将编译并执行以生成以下输出:

slide created successfully

带有新添加的标题布局幻灯片的PPT文档如下所示:

以同样的方式,您也可以创建具有不同布局的幻灯片。

Apache POI PPT - 幻灯片管理

完成本章后,您将能够在幻灯片上删除,重新排序和执行读取和写入操作。

更改幻灯片

我们可以使用 XMLSlideShow 类的 setPageSize()方法更改幻灯片的页面大小。

最初创建演示文稿如下所示:

File file=new File("C://POIPPT//Examples// TitleAndContentLayout.pptx");
//create presentation
XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));

使用 XMLSlideShow 类的 getPageSize()方法获取当前幻灯片的大小。

java.awt.Dimension pgsize = ppt.getPageSize();

使用 setPageSize()方法设置页面的大小。

ppt.setPageSize(new java.awt.Dimension(1024, 768));

改变幻灯片大小的完整程序如下:

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import org.apache.poi.xslf.usermodel.XMLSlideShow;

public class ChangingSlide {
   
   public static void main(String args[]) throws IOException{

      //create file object
      File file = new File("TitleAndContentLayout.pptx");
	 
      //create presentation
      XMLSlideShow ppt = new XMLSlideShow();
      
      //getting the current page size
      java.awt.Dimension pgsize = ppt.getPageSize();
      int pgw = pgsize.width; //slide width in points
      int pgh = pgsize.height; //slide height in points
      System.out.println("current page size of the PPT is:");
      System.out.println("width :" + pgw);
      System.out.println("height :" + pgh);
      
      //set new page size
      ppt.setPageSize(new java.awt.Dimension(2048,1536));
      
      //creating file object
      FileOutputStream out = new FileOutputStream(file);
      
      //saving the changes to a file
      ppt.write(out);
      System.out.println("slide size changed to given dimentions ");
      out.close();	
   }
}

将上述Java代码保存为 ChangingSlide.java ,然后从命令提示符处编译并执行它,如下所示:

$javac ChangingSlide.java
$java ChangingSlide

它将编译并执行以生成以下输出。

current page size of the presentation is : 
width :720
height :540
slide size changed to given dimensions

以下是更改幻灯片大小之前演示文稿的快照:

更改其大小后,幻灯片显示如下:

重新排序幻灯片

您可以使用 setSlideOrder()方法设置幻灯片顺序。 下面给出了设置幻灯片顺序的过程。

打开现有PPT文档,如下所示:

File file=new File("C://POIPPT//Examples//example1.pptx");
XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));

使用 getSlides()方法获取幻灯片,如下所示:

XSLFSlide[] slides =ppt.getSlides();

从幻灯片数组中选择一张幻灯片,然后使用 setSlideOrder()方法更改顺序,如下所示:

//selecting the fourth slide
XSLFSlide selectesdslide= slides[4];
//bringing it to the top
ppt.setSlideOrder(selectesdslide, 1);

下面给出了在演示文稿中重新排序幻灯片的完整程序:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class ReorderSlide {	
   
   public static void main(String args[]) throws IOException{
   
      //opening an existing presentation
      File file=new File("example1.pptx");
      XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));
      
      //get the slides 
      XSLFSlide[] slides = ppt.getSlides();    
      
      //selecting the fourth slide
      XSLFSlide selectesdslide = slides[13];
      
      //bringing it to the top
      ppt.setSlideOrder(selectesdslide, 0);
      
      //creating an file object 
      FileOutputStream out = new FileOutputStream(file);
	  
      //saving the changes to a file
      ppt.write(out);
      out.close();	
   }
}

将上述Java代码另存为 ReorderSlide.java ,然后从命令提示符处编译并执行,如下所示:

$javac  ReorderSlide.java
$java ReorderSlide

它将编译并执行以生成以下输出。

Reordering of the slides is done

下面是重新排序幻灯片之前的演示的快照:

重新排序幻灯片后,演示文稿如下所示。 在这里,我们选择了幻灯片与图像,并将其移动到顶部。

正在删除幻灯片

您可以使用 removeSlide()方法删除幻灯片。 按照以下步骤删除幻灯片。

使用 XMLSlideShow 类打开现有演示文稿,如下所示:

File file=new File("C://POIPPT//Examples//image.pptx");
XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));

使用 removeSlide()方法删除所需的幻灯片。 此方法接受整数参数。 将要删除的幻灯片的索引传递给此方法。

ppt.removeSlide(1);

以下是从演示文稿中删除幻灯片的程序:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;

public class Deleteslide { 
   
   public static void main(String args[]) throws IOException{
   
      //Opening an existing slide
      File file=new File("image.pptx");
      XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));
      
      //deleting a slide
      ppt.removeSlide(1);
      
      //creating a file object
      FileOutputStream out = new FileOutputStream(file);
      
      //Saving the changes to the presentation
      ppt.write(out);
      out.close();	
   }
}

将上述Java代码保存为 Deleteslide.java ,然后从命令提示符处编译并执行,如下所示:

$javac  Deleteslide.java
$java Deleteslide

它将编译并执行以生成以下输出:

reordering of the slides is done

下面的快照是删除幻灯片之前的演示文稿:

删除幻灯片后,演示显示如下:

Apache POI PPT - 图像

在本章中,您将学习如何将图像添加到PPT以及如何从中读取图像。

添加图像

您可以使用 XSLFSlide createPicture()方法将图片添加到演示文稿。 此方法接受以字节数组格式形式的图像。 因此,您必须创建要添加到演示文稿的图像的字节数组。

按照给定的过程向演示文稿添加图像。 使用 XMLSlideShow 创建空白幻灯片,如下所示:

XMLSlideShow ppt = new XMLSlideShow();

使用 createSlide()创建一个空的演示文稿。

XSLFSlide slide = ppt.createSlide();

使用 IOUtils 类的 IOUtils.toByteArray()读取要添加的图像文件并将其转换为字节数组,如下所示:

//reading an image
File image=new File("C://POIPPT//boy.jpg");
//converting it into a byte array
byte[] picture = IOUtils.toByteArray(new FileInputStream(image));

使用 addPicture()将图片添加到演示文稿。 此方法接受两个变量:要添加的图像的字节数组格式和表示图像的文件格式的静态变量。 addPicture()方法的用法如下所示:

int idx = ppt.addPicture(picture, XSLFPictureData.PICTURE_TYPE_PNG);

使用 createPicture()将图片嵌入幻灯片,如下所示:

XSLFPictureShape pic = slide.createPicture(idx);

下面给出了在演示文稿中向幻灯片添加图片的完整程序:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.util.IOUtils;
import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFPictureData;
import org.apache.poi.xslf.usermodel.XSLFPictureShape;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class AddingImage {
   
   public static void main(String args[]) throws IOException{
   
      //creating a presentation 
      XMLSlideShow ppt = new XMLSlideShow();
      
      //creating a slide in it 
      XSLFSlide slide = ppt.createSlide();
      
      //reading an image
      File image=new File("C://POIPPT//boy.jpg");
      
      //converting it into a byte array
      byte[] picture = IOUtils.toByteArray(new FileInputStream(image));
      
      //adding the image to the presentation
      int idx = ppt.addPicture(picture, XSLFPictureData.PICTURE_TYPE_PNG);
      
      //creating a slide with given picture on it
      XSLFPictureShape pic = slide.createPicture(idx);
      
      //creating a file object 
      File file=new File("addingimage.pptx");
      FileOutputStream out = new FileOutputStream(file);
      
      //saving the changes to a file
      ppt.write(out)
      System.out.println("image added successfully");
      out.close();	
   }
}

将上述Java代码保存为 AddingImage.java ,然后从命令提示符处编译并执行,如下所示:

$javac  AddingImage.java
$java AddingImage

它将编译并执行以生成以下输出:

reordering of the slides is done

带有新添加的带有图像的幻灯片的演示文稿如下所示:

阅读图像

您可以使用 XMLSlideShow 类的 getAllPictures()方法获取所有图片的数据。 以下程序从演示文稿读取图像:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFPictureData;

public class Readingimage {
  
  public static void main(String args[]) throws IOException{
   
      //open an existing presentation 
      File file = new File("addingimage.pptx");
      XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));
      
      //reading all the pictures in the presentation
      for(XSLFPictureData data : ppt.getAllPictures()){
         
         byte[] bytes = data.getData();
         String fileName = data.getFileName();
         int pictureFormat = data.getPictureType();
         System.out.println("picture name: " + fileName);
         System.out.println("picture format: " + pictureFormat);   
      }	    
      
      //saving the changes to a file
      FileOutputStream out = new FileOutputStream(file);
      ppt.write(out);
      out.close();	
   }
}

将上述Java代码保存为 Readingimage.java ,然后从命令提示符处编译并执行,如下所示:

$javac  Readingimage.java
$java Readingimage

它将编译并执行以生成以下输出:

picture name: image1.png
picture format: 6 

Apache POI PPT - 创建超链接

在本章中,您将学习如何在演示文稿中创建超链接。

创建超链接

您可以使用 XSLFTextRun 类的 createHyperlink()方法读取演示文稿中的超链接。 按照下面给出的过程在演示中创建超链接。

使用 XMLSlideShow 类创建一个空的演示文稿,如下所示:

XMLSlideShow ppt = new XMLSlideShow();

创建一个空白幻灯片,并使用正文和内容布局创建幻灯片的文本框和正文。

//create an empty presentation
XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];
//creating a slide with title and content layout
XSLFSlideLayout slidelayout = slideMaster.getLayout(SlideLayout.TITLE_AND_CONTENT);
XSLFSlide slide = ppt.createSlide(slidelayout);
//selection of body place holder
XSLFTextShape body = slide.getPlaceholder(1);
//clear the existing text in the slide
body.clearText();

创建一个文本运行对象并设置文本到它,如下所示:

XSLFTextRun textRun=body.addNewTextParagraph().addNewTextRun();
textRun.setText("Tutorials point");

使用 XSLFTextRun 类的 createHyperlink()方法创建超链接,如下所示:

XSLFHyperlink link = textRun.createHyperlink();

使用 XSLFHyperlink 类的 setAddress()方法将链接地址设置为超链接,如下所示:

link.setAddress("//www.w3cschool.cn/");

下面给出了在演示文稿中创建超链接的完整程序:

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.SlideLayout;
import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFHyperlink;
import org.apache.poi.xslf.usermodel.XSLFSlide;
import org.apache.poi.xslf.usermodel.XSLFSlideLayout;
import org.apache.poi.xslf.usermodel.XSLFSlideMaster;
import org.apache.poi.xslf.usermodel.XSLFTextRun;
import org.apache.poi.xslf.usermodel.XSLFTextShape;

public class CreatingHyperlinks {

   public static void main(String args[]) throws IOException{
      
      //create an empty presentation
      XMLSlideShow ppt = new XMLSlideShow();
      
      //getting the slide master object
      XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];
      
      //select a layout from specified list
      XSLFSlideLayout slidelayout = slideMaster.getLayout(SlideLayout.TITLE_AND_CONTENT);
     
      //creating a slide with title and content layout
      XSLFSlide slide = ppt.createSlide(slidelayout);
      
      //selection of title place holder
      XSLFTextShape body = slide.getPlaceholder(1);
      
      //clear the existing text in the slid
      body.clearText();
      
      //adding new paragraph
      XSLFTextRun textRun = body.addNewTextParagraph().addNewTextRun();
      
      //setting the text
      textRun.setText("Tutorials point");	
      //creating the hyperlink
      XSLFHyperlink link = textRun.createHyperlink();
      
      //setting the link address
      link.setAddress("//www.w3cschool.cn/");
      
      //create the file object            
      File file=new File("hyperlink.pptx");
      FileOutputStream out = new FileOutputStream(file);
      
      //save the changes in a file
      ppt.write(out);
      System.out.println("slide cretated successfully");
      out.close();              
   }
}

将上述Java代码保存为 CreatingHyperlinks.java ,然后从命令提示符处编译并执行,如下所示:

$javac  CreatingHyperlinks.java
$java CreatingHyperlinks

它将编译并执行以生成以下输出:

slide cretated successfully 

新添加的幻灯片及其正文中的超链接如下所示:

Apache POI PPT - 阅读形状

从介绍的读书形状

您可以使用 XSLFShape 类的方法 getShapeName()来计算演示文稿中使用的形状数量。 下面给出的是从演示中读取形状的程序:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFShape;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class ReadingShapes {
   
   public static void main(String args[]) throws IOException{
      
      //creating a slideshow 
      File file = new File("shapes.pptx");
      XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));
      
      //get slides 
      XSLFSlide[] slide = ppt.getSlides();
      
      //getting the shapes in the presentation
      System.out.println("Shapes in the presentation:");
      for (int i = 0; i < slide.length; i++){
         
         XSLFShape[] sh = slide[i].getShapes();
         for (int j = 0; j < sh.length; j++){
            
            //name of the shape
            System.out.println(sh[j].getShapeName());
         }
      }
      FileOutputStream out = new FileOutputStream(file);
      ppt.write(out);
      out.close();	
   }
}

将上述Java代码另存为 ReadingShapes.java ,然后从命令提示符处编译并执行,如下所示:

$javac  ReadingShapes.java
$java ReadingShapes

它将编译并执行以生成以下输出。

Shapes in the presentation: 
Rectangle 1
Oval 1
Isosceles Triangle 1

新添加的具有各种形状的幻灯片显示如下:

Apache POI PPT - 格式化文本

格式化演示文稿中的文本

可以使用 XSLFTextRun 类的方法来格式化演示文稿中的文本。 为此,您必须通过选择一个幻灯片布局来创建一个 XSLFTextRun 类对象,如下所示:

//create the empty presentation 
XMLSlideShow ppt = new XMLSlideShow();
//getting the slide master object
XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];
//select a layout from specified list
XSLFSlideLayout slidelayout = slideMaster.getLayout(SlideLayout.TITLE_AND_CONTENT);
//creating a slide with title and content layout
XSLFSlide slide = ppt.createSlide(slidelayout);
//selection of title place holder
XSLFTextShape body = slide.getPlaceholder(1);
//clear the existing text in the slide
body.clearText();
//adding new paragraph
XSLFTextParagraph paragraph=body.addNewTextParagraph();
//creating text run object
XSLFTextRun run = paragraph.addNewTextRun();

您可以使用 setFontSize()设置演示文稿中文本的字体大小。

run.setFontColor(java.awt.Color.red);
run.setFontSize(24);

以下代码段显示了如何对演示文稿中的文字应用不同的格式样式(粗体,斜体,下划线,删除线)。

//change the text into bold format
run.setBold(true);
//change the text it to italic format
run.setItalic(true)
// strike through the text
run.setStrikethrough(true);
//underline the text
run.setUnderline(true);

要在段落之间使用换行符,请使用 XSLFTextParagraph 类的 addLineBreak(),如下所示:

paragraph.addLineBreak();

下面给出了使用所有上述方法来格式化文本的完整程序:

import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.SlideLayout;
import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;
import org.apache.poi.xslf.usermodel.XSLFSlideLayout;
import org.apache.poi.xslf.usermodel.XSLFSlideMaster;
import org.apache.poi.xslf.usermodel.XSLFTextParagraph;
import org.apache.poi.xslf.usermodel.XSLFTextRun;
import org.apache.poi.xslf.usermodel.XSLFTextShape;

public class TextFormating {
   
   public static void main(String args[]) throws IOException{
      
      //creating an empty presentation
      XMLSlideShow ppt = new XMLSlideShow();
      
      //getting the slide master object
      XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];
      
      //select a layout from specified list
      XSLFSlideLayout slidelayout = slideMaster.getLayout(SlideLayout.TITLE_AND_CONTENT);
      
      //creating a slide with title and content layout
      XSLFSlide slide = ppt.createSlide(slidelayout);
      
      //selection of title place holder
      XSLFTextShape body = slide.getPlaceholder(1);
      
      //clear the existing text in the slide
      body.clearText();
      
      //adding new paragraph
      XSLFTextParagraph paragraph=body.addNewTextParagraph();
      
      //formatting line1
      XSLFTextRun run1 = paragraph.addNewTextRun();
      run1.setText("This is a colored line");      
      //setting color to the text
      run1.setFontColor(java.awt.Color.red);      
      //setting font size to the text
      run1.setFontSize(24);      
      //moving to the next line
      paragraph.addLineBreak();
     
      //formatting line2
      XSLFTextRun run2 = paragraph.addNewTextRun();
      run2.setText("This is a bold line");
      run2.setFontColor(java.awt.Color.CYAN);
      //making the text bold
      run2.setBold(true);
      paragraph.addLineBreak();
      
      //formatting line3
      XSLFTextRun run3 = paragraph.addNewTextRun();
      run3.setText(" This is a striked line");
      run3.setFontSize(12);
      //making the text italic
      run3.setItalic(true);
      //strike through the text
      run3.setStrikethrough(true);
      paragraph.addLineBreak();
      
      //formatting line4
      XSLFTextRun run4 = paragraph.addNewTextRun();
      run4.setText(" This an underlined line");
      run4.setUnderline(true);
      //underlining the text
      paragraph.addLineBreak();
      //creating a file object
      File file=new File(“TextFormat.pptx");
      FileOutputStream out = new FileOutputStream(file);
      saving the changes to a file
      ppt.write(out);
      out.close();	 
   }
}

将上述代码保存为 TextFormating.java ,然后从命令提示符处编译并执行,如下所示:

$javac  TextFormating.java
$java TextFormating

它将编译并执行以生成以下输出:

Formatting completed successfully 

带有格式化文本的幻灯片如下所示:

Apache POI PPT - 合并

合并多个演示文稿

您可以使用 XMLSlideShow 类的 importContent()方法合并多个演示文稿。 下面给出的是合并两个演示文稿的完整程序:

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class MergingMultiplePresentations {
   
      public static void main(String args[]) throws IOException{
      
      //creating empty presentation
      XMLSlideShow ppt = new XMLSlideShow();
      
      //taking the two presentations that are to be merged 
      String file1 = "presentation1.pptx";
      String file2 = "presentation2.pptx";
      String[] inputs = {file1, file2};
      
      for(String arg : inputs){
      
         FileInputStream inputstream = new FileInputStream(arg);
         XMLSlideShow src = new XMLSlideShow(inputstream);
         for(XSLFSlide srcSlide : src.getSlides()){
         
            //merging the contents
            ppt.createSlide().importContent(srcSlide);
         }
      }
     
      String file3 = "combinedpresentation.pptx";
      
      //creating the file object
      FileOutputStream out = new FileOutputStream(file3);
      
      // saving the changes to a file
      ppt.write(out);
      System.out.println("Merging done successfully");
      out.close();
   }
}

将上述代码保存为 MergingMultiplePresentations.java ,然后从命令提示符处编译并执行它,如下所示:

$javac  MergingMultiplePresentations.java
$java MergingMultiplePresentations

它将编译并执行以生成以下输出:

Merging done successfully

以下快照显示第一个演示:

以下快照显示第二个演示:

下面给出合并两个幻灯片后程序的输出。 在这里您可以看到合并在一起的早期幻灯片的内容。

Apache POI PPT - PPT到映像

将演示文稿转换为图像

您可以将演示文稿转换为图像文件。 以下程序显示了如何去做。

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class PpttoPNG {
   
   public static void main(String args[]) throws IOException{
      
      //creating an empty presentation
      File file=new File("addingimage.pptx");
      XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));
      
      //getting the dimensions and size of the slide 
      Dimension pgsize = ppt.getPageSize();
      XSLFSlide[] slide = ppt.getSlides();
      for (int i = 0; i < slide.length; i++) {
      BufferedImage img = new BufferedImage(pgsize.width, pgsize.height,BufferedImage.TYPE_INT_RGB);
      Graphics2D graphics = img.createGraphics();
      
      //clear the drawing area
      graphics.setPaint(Color.white);
      graphics.fill(new Rectangle2D.Float(0, 0, pgsize.width, pgsize.height));
      
      //render
      slide[i].draw(graphics);
      
      //creating an image file as output
      FileOutputStream out = new FileOutputStream("ppt_image.png");
      javax.imageio.ImageIO.write(img, "png", out);
      ppt.write(out);
      System.out.println("Image successfully created");
      out.close();	
   }
}

将上述Java代码另存为 PpttoPNG.java ,然后从命令提示符处编译并执行它,如下所示:

$javac  PpttoPNG.java
$java PpttoPNG

它将编译并执行以生成以下输出:

Image created successfully

以下快照显示了作为输入的演示:

下面给出了在指定位置创建的映像的快照。


以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号