CustomPartCollection

CustomPartCollection class

代表一个集合CustomPart对象.

public class CustomPartCollection : IEnumerable<CustomPart>

构造函数

姓名 描述
CustomPartCollection() 默认构造函数。

特性

姓名 描述
Count { get; } 获取集合中包含的元素数。
Item { get; set; } 获取或设置指定索引处的项目。

方法

姓名 描述
Add(CustomPart) 将一个项目添加到集合中。
Clear() 从集合中删除所有元素。
Clone() 制作此集合及其项目的深层副本。
GetEnumerator() 返回一个可用于迭代集合中所有项目的枚举器对象。
RemoveAt(int) 删除指定索引处的项目。

评论

您通常不需要创建此类的实例。您可以通过以下方式访问与 OOXML 包相关的自定义部件 PackageCustomParts财产。

例子

显示如何访问文档的任意自定义部件集合。

Document doc = new Document(MyDir + "Custom parts OOXML package.docx");

Assert.AreEqual(2, doc.PackageCustomParts.Count);

// 克隆第二部分,然后将克隆添加到集合中。
CustomPart clonedPart = doc.PackageCustomParts[1].Clone();
doc.PackageCustomParts.Add(clonedPart);
Assert.AreEqual(3, doc.PackageCustomParts.Count);

// 枚举集合并打印每个部分。
using (IEnumerator<CustomPart> enumerator = doc.PackageCustomParts.GetEnumerator())
{
    int index = 0;
    while (enumerator.MoveNext())
    {
        Console.WriteLine($"Part index {index}:");
        Console.WriteLine($"\tName:\t\t\t\t{enumerator.Current.Name}");
        Console.WriteLine($"\tContent type:\t\t{enumerator.Current.ContentType}");
        Console.WriteLine($"\tRelationship type:\t{enumerator.Current.RelationshipType}");
        Console.WriteLine(enumerator.Current.IsExternal ?
            "\tSourced from outside the document" :
            $"\tStored within the document, length: {enumerator.Current.Data.Length} bytes");
        index++;
    }
}

// 我们可以从这个集合中单独删除元素,也可以一次全部删除。
doc.PackageCustomParts.RemoveAt(2);

Assert.AreEqual(2, doc.PackageCustomParts.Count);

doc.PackageCustomParts.Clear();

Assert.AreEqual(0, doc.PackageCustomParts.Count);

也可以看看