-
C# 添加、删除、读取Word形状(基于Spire.Cloud.Word.SDK)
本文介绍调用Spire.Cloud.SDK for .NET 提供的接口shapesApi来操作Word形状,包括添加形状AddShape(),添加形状时,可设置形状类型、颜色、大小、位置、倾斜、轮廓、文本环绕方式、顺序);删除形状DeleteShape()和读取形状属性GetShapeProperties()等。调用接口方法及步骤参考以下步骤:
步骤一:dll文件获取及导入。在程序中通过Nuget搜索下载,直接导入所有dll。dll引用结果如下图所示:
步骤二:App ID及Key获取。在“我的应用”板块中创建应用以获得App ID及App Key。
步骤三:源文档上传。在“文档管理”板块,上传源文档。这里可以建文件夹,将文档存放在文件夹下。不建文件夹时,源文档及结果文档直接保存在根目录。本文示例中,建了两个文件夹,分别用于存放源文档及结果文档。(云平台提供免费1 万次调用次数和 2G 文档内存)
C# 示例代码
1. 添加形状到Word
using System; using Spire.Cloud.Word.Sdk.Client; using Spire.Cloud.Word.Sdk.Api; using Spire.Cloud.Word.Sdk.Model; namespace AddShape { class Program { //配置AppID和AppKey static string appId = "App ID"; static string appKey = "App Key"; static string basePath = "https://api.e-iceblue.cn"; static Configuration wordConfiguration = new Configuration(appId, appKey, basePath); static ShapesApi shapesApi = new ShapesApi(wordConfiguration); static void Main(string[] args) { //实例化ShapesApi类 ShapesApi shapesApi = new ShapesApi(wordConfiguration); string name = "test.docx";//源文档 string paragraphPath = "sections/0/paragraphs/0";//段落路径 int indexInParagraph = 1;//添加形状的段落 string folder = "input";//源文档所在文件夹 string storage = null;//使用冰蓝云配置的2G空间存贮文档,可设置为null string password = null;//源文档密码 //设置形状属性(包括形状类型、位置、填充颜色、旋转方向、边框宽度/颜色、文本环绕类型/方式 ShapeFormat shapeformat = new ShapeFormat(50, 50, ShapeFormat.ShapeTypeEnum.Star) { HorizontalOrigin = ShapeFormat.HorizontalOriginEnum.Page, VerticalOrigin = ShapeFormat.VerticalOriginEnum.Page, VerticalPosition = 40, HorizontalPosition = 230, FillColor = new Color(255, 69, 0), Rotation = 45, StrokeWeight = 2, StrokeColor = new Color(255, 255, 0), TextWrappingType = ShapeFormat.TextWrappingTypeEnum.Both, TextWrappingStyle = ShapeFormat.TextWrappingStyleEnum.InFrontOfText, ZOrder = 1 }; string destFilePath = "output/AddShape.docx";//结果文档路径 //调用方法添加形状 shapesApi.AddShape(name,paragraphPath,shapeformat,destFilePath,folder,storage,indexInParagraph,password); } } }
形状添加效果:
2. 删除Word中的形状
using System; using Spire.Cloud.Word.Sdk.Api; using Spire.Cloud.Word.Sdk.Client; namespace DeleteShape { class Program { //配置AppID和AppKey static string appId = "App ID"; static string appKey = "App Key"; static string basePath = "https://api.e-iceblue.cn"; static Configuration wordConfiguration = new Configuration(appId, appKey, basePath); static ShapesApi shapesApi = new ShapesApi(wordConfiguration); static void Main(string[] args) { //实例化ShapesApi类 ShapesApi shapesApi = new ShapesApi(wordConfiguration); string name = "AddShape.docx";//源文档 string paragraphPath = "sections/0/paragraphs/0";//段落路径 int index = 0;//要删除形状的索引 string folder = "output";//源文档所在文件夹 string storage = null;//使用冰蓝云配置的2G空间存贮文档,可设置为null string password = null;//源文档密码 string destFilePath = "output/DeleteShape.docx";//结果文档路径 //调用方法删除形状 shapesApi.DeleteShape(name,paragraphPath,index,destFilePath,folder,storage,password); } } }
形状删除效果:
3. 读取Word形状属性
using System; using Spire.Cloud.Word.Sdk.Client; using Spire.Cloud.Word.Sdk.Api; namespace GetShapeProperties { class Program { //配置账号信息 static string appId = "App ID"; static string appKey = "App Key"; static string basePath = "https://api.e-iceblue.cn"; static Configuration wordConfiguration = new Configuration(appId, appKey, basePath); static ShapesApi shapesApi = new ShapesApi(wordConfiguration); static void Main(string[] args) { //实例化ShapesApi类 ShapesApi shapesApi = new ShapesApi(wordConfiguration); string name = "AddShape.docx";//源文档 string paragraphPath = "Section/0/Body/0/Paragraph/0"; int index = 0;//读取的形状索引 string folder = "output";//源文档所在文件夹 string storage = null;//使用冰蓝云配置的2G空间存贮文档,可设置为null string password = null;//源文档密码 //读取属性 System.Console.WriteLine(shapesApi.GetShapeFormat(name, paragraphPath, index, folder, storage, password)); System.Console.ReadLine(); } } }
属性读取结果:
(完)
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式