Spire.Cloud.Word 替换 Word 中的文本

 

Spire.Cloud.Word 提供的 ReplaceTextApi 用于替换 Word 文档中的文本,本文介绍如何替换指定文本以及符合正则表达式的文本。

步骤一:创建一个 Maven 程序,通过 Maven 仓库安装 Spire.Cloud.SDK,详细步骤可参考这篇文章

步骤二:通过冰蓝云官网(https://cloud.e-iceblue.cn/)注册账号并登陆,在“我的应用”版块创建应用程序,获得 App ID 及 App Key。

步骤三:上传 Word 文档至冰蓝云官网的“文档管理”版块。为了便于文档管理,您也可以先创建文件夹 "input" 和 "output",然后将需要编辑的 Word 文档上传至 input 文件夹下,output 文件夹用于存放生成的文档。本教程将示例文档(sample.docx)上传到了 input 文件夹下。

Spire.Cloud.Word 替换 Word 中的文本

步骤四:在Maven程序中编写测试类操作 input 文件夹下的文档。


示例 1、 替换指定文本

import spire.cloud.word.sdk.client.*;
import spire.cloud.word.sdk.client.api.ReplaceTextApi;

public class ReplaceText {

    static String appId = "App ID";
    static String appKey = "App Key";
    static String baseUrl = "https://api.e-iceblue.cn";

    //配置App ID和App Key
    static Configuration wordConfiguration = new Configuration(appId, appKey, baseUrl);

    //初始化ReplaceTextApi对象
    static ReplaceTextApi replaceTextApi = new ReplaceTextApi(wordConfiguration);

    public static void main(String[] args) throws Exception {

        //指定要编辑的文档名称
        String name = "sample.docx";

        //指定需要替换的文本
        String oldValue = "Spire.Cloud.Word";

        //指定替换进去的文本
        String newValue = "冰蓝云Word SDK";

        //指定生成的文档路径
        String destFilePath = "output/ReplaceWithText.docx"; ;

        //指定源文档打开密码,无密码则为null
        String password = null;

        //指定存放源文档的文件夹
        String folder = "input";

        //使用冰蓝云默认的存储空间,将storage设置为null
        String storage = null;

        //是否匹配大小写
        Boolean matchCase = false;

        //是否匹配整个搜索的字符串
        Boolean matchWholeWord = true;

        //是否只替换一个
        Boolean replaceFirst = false;

        //调用relaceWithText方法替换文本
        replaceTextApi.replaceWithText(name, oldValue, newValue, destFilePath, password, folder, storage, matchCase, matchWholeWord, replaceFirst);
    }
}

Spire.Cloud.Word 替换 Word 中的文本

示例 2、替换符合正则表达式的文本

import spire.cloud.word.sdk.client.*;
import spire.cloud.word.sdk.client.api.ReplaceTextApi;

import java.io.File;

public class ReplaceWithRegex {

    static String appId = "App ID";
    static String appKey = "App Key";
    static String baseUrl = "https://api.e-iceblue.cn";

    //配置App ID和App Key
    static Configuration wordConfiguration = new Configuration(appId, appKey, baseUrl);

    //初始化ReplaceTextApi对象
    static ReplaceTextApi replaceTextApi = new ReplaceTextApi(wordConfiguration);

    public static void main(String[] args) throws ApiException {

        //指定要编辑的文档名称
        String name = "sample.docx";

        //指定正则表达式(以#开头的字符串)
        String regex = "\\#\\w+\\b";

        //指定替换进去的文本
        String newValue = "软件开发工具包";

        //指定生成的文档路径
        String destFilePath = "output/ReplaceWithRegex.docx";

        //指定源文档打开密码,无密码则为null
        String password = null;

        //指定存放源文档的文件夹
        String folder = "input";

        //使用冰蓝云默认的存储空间,将storage设置为null
        String storage = null;

        //调用replaceWithRegex替换符合正则表式的文本
        replaceTextApi.replaceWithRegex(name, regex, newValue, destFilePath, password, folder, storage);
    }
}

Spire.Cloud.Word 替换 Word 中的文本