FieldMergeRec
内容
[
隐藏
]FieldMergeRec class
实现 MERGEREC 字段。
要了解更多信息,请访问使用字段文档文章。
public class FieldMergeRec : Field
构造函数
姓名 | 描述 |
---|---|
FieldMergeRec() | 默认构造函数。 |
特性
姓名 | 描述 |
---|---|
DisplayResult { get; } | 获取表示显示字段结果的文本。 |
End { get; } | 获取代表字段结束的节点。 |
Format { get; } | 获得FieldFormat 提供对字段格式进行类型化访问的对象。 |
IsDirty { get; set; } | 获取或设置字段的当前结果是否由于对文档所做的其他修改而不再正确(陈旧)。 |
IsLocked { get; set; } | 获取或设置字段是否被锁定(不应重新计算其结果)。 |
LocaleId { get; set; } | 获取或设置字段的 LCID。 |
Result { get; set; } | 获取或设置字段分隔符和字段结尾之间的文本。 |
Separator { get; } | 获取表示字段分隔符的节点。可以是无效的 . |
Start { get; } | 获取表示字段开始的节点。 |
virtual Type { get; } | 获取 Microsoft Word 字段类型。 |
方法
姓名 | 描述 |
---|---|
GetFieldCode() | 返回字段开始和字段分隔符之间的文本(如果没有分隔符,则返回字段结束)。 包括子字段的字段代码和字段结果。 |
GetFieldCode(bool) | 返回字段开始和字段分隔符之间的文本(如果没有分隔符,则返回字段结束)。 |
Remove() | 从文档中移除该字段。返回紧接该字段之后的节点。如果该字段的末尾是其父节点的最后一个 child ,则返回其父段落。如果该字段已被移除,则返回无效的 . |
Unlink() | 执行字段取消链接。 |
Update() | 执行字段更新。如果字段已在更新,则抛出异常。 |
Update(bool) | 执行字段更新。如果字段已在更新,则抛出异常。 |
评论
目前 MERGEREC 和 MERGESEQ 字段实现相同的功能,因为我们不确定 如何在 Aspose.Words 邮件合并中跳过记录。
例子
展示如何使用 MERGEREC 和 MERGESEQ 字段对邮件合并输出文档中的邮件合并记录进行编号和计数。
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
builder.Write("Dear ");
FieldMergeField fieldMergeField = (FieldMergeField)builder.InsertField(FieldType.FieldMergeField, true);
fieldMergeField.FieldName = "Name";
builder.Writeln(",");
// MERGEREC 字段将打印每个合并输出文档中正在合并的数据的行号。
builder.Write("\nRow number of record in data source: ");
FieldMergeRec fieldMergeRec = (FieldMergeRec)builder.InsertField(FieldType.FieldMergeRec, true);
Assert.AreEqual(" MERGEREC ", fieldMergeRec.GetFieldCode());
// MERGESEQ 字段将计算成功合并的次数并在每个相应的页面上打印当前值。
// 如果邮件合并没有跳过任何行并且没有调用任何 SKIP/SKIPIF/NEXT/NEXTIF 字段,则所有合并都成功。
// MERGESEQ 和 MERGEREC 字段将显示相同的邮件合并成功结果。
builder.Write("\nSuccessful merge number: ");
FieldMergeSeq fieldMergeSeq = (FieldMergeSeq)builder.InsertField(FieldType.FieldMergeSeq, true);
Assert.AreEqual(" MERGESEQ ", fieldMergeSeq.GetFieldCode());
// 插入一个 SKIPIF 字段,如果名称是“John Doe”,则将跳过合并。
FieldSkipIf fieldSkipIf = (FieldSkipIf)builder.InsertField(FieldType.FieldSkipIf, true);
builder.MoveTo(fieldSkipIf.Separator);
fieldMergeField = (FieldMergeField)builder.InsertField(FieldType.FieldMergeField, true);
fieldMergeField.FieldName = "Name";
fieldSkipIf.LeftExpression = "=";
fieldSkipIf.RightExpression = "John Doe";
// 创建一个包含 3 行的数据源,其中一行的“Name”列的值为“John Doe”。
// 由于 SKIPIF 字段将被该值触发一次,因此我们的邮件合并输出将有 2 页而不是 3 页。
// 在第 1 页上,MERGESEQ 和 MERGEREC 字段都将显示“1”。
// 在第 2 页上,MERGEREC 字段将显示“3”,MERGESEQ 字段将显示“2”。
DataTable table = new DataTable("Employees");
table.Columns.Add("Name");
table.Rows.Add("Jane Doe");
table.Rows.Add("John Doe");
table.Rows.Add("Joe Bloggs");
doc.MailMerge.Execute(table);
doc.Save(ArtifactsDir + "Field.MERGEREC.MERGESEQ.docx");
也可以看看
- class Field
- 命名空间 Aspose.Words.Fields
- 部件 Aspose.Words