VariableCollection
内容
[
隐藏
]VariableCollection class
文档变量的集合。
要了解更多信息,请访问使用文档属性文档文章。
public class VariableCollection : IEnumerable<KeyValuePair<string, string>>
特性
姓名 | 描述 |
---|---|
Count { get; } | 获取集合中包含的元素数量。 |
Item { get; set; } | 通过不区分大小写的名称获取或设置文档变量。 无效的 值不允许作为赋值的右侧,并将被空字符串替换。 (2 indexers) |
方法
姓名 | 描述 |
---|---|
Add(string, string) | 将文档变量添加到集合中。 |
Clear() | 从集合中删除所有元素。 |
Contains(string) | 确定集合中是否包含具有给定名称的文档变量。 |
GetEnumerator() | 返回一个枚举器对象,可用于迭代集合中的所有变量。 |
IndexOfKey(string) | 返回集合中指定文档变量的从零开始的索引。 |
Remove(string) | 从集合中删除具有指定名称的文档变量。 |
RemoveAt(int) | 删除指定索引处的文档变量。 |
评论
变量名称和值是字符串。
变量名不区分大小写。
例子
展示如何使用文档的变量集合。
Document doc = new Document();
VariableCollection variables = doc.Variables;
// 每个文档都有一个键/值对变量的集合,我们可以向其中添加项目。
variables.Add("Home address", "123 Main St.");
variables.Add("City", "London");
variables.Add("Bedrooms", "3");
Assert.AreEqual(3, variables.Count);
// 我们可以使用 DOCVARIABLE 字段在文档正文中显示变量的值。
DocumentBuilder builder = new DocumentBuilder(doc);
FieldDocVariable field = (FieldDocVariable)builder.InsertField(FieldType.FieldDocVariable, true);
field.VariableName = "Home address";
field.Update();
Assert.AreEqual("123 Main St.", field.Result);
// 为现有键分配值将更新它们。
variables.Add("Home address", "456 Queen St.");
// 然后我们必须更新 DOCVARIABLE 字段以确保它们显示最新值。
Assert.AreEqual("123 Main St.", field.Result);
field.Update();
Assert.AreEqual("456 Queen St.", field.Result);
// 验证具有特定名称或值的文档变量是否存在。
Assert.True(variables.Contains("City"));
Assert.True(variables.Any(v => v.Value == "London"));
// 变量集合自动按名称字母顺序对变量进行排序。
Assert.AreEqual(0, variables.IndexOfKey("Bedrooms"));
Assert.AreEqual(1, variables.IndexOfKey("City"));
Assert.AreEqual(2, variables.IndexOfKey("Home address"));
// 枚举变量集合。
using (IEnumerator<KeyValuePair<string, string>> enumerator = doc.Variables.GetEnumerator())
while (enumerator.MoveNext())
Console.WriteLine($"Name: {enumerator.Current.Key}, Value: {enumerator.Current.Value}");
// 下面是从集合中删除文档变量的三种方法。
// 1 - 按名称:
variables.Remove("City");
Assert.False(variables.Contains("City"));
// 2 - 按索引:
variables.RemoveAt(1);
Assert.False(variables.Contains("Home address"));
// 3 - 立即清除整个集合:
variables.Clear();
Assert.That(variables, Is.Empty);
也可以看看
- 命名空间 Aspose.Words
- 部件 Aspose.Words