LeftExpression
FieldSkipIf.LeftExpression property
获取或设置比较表达式的左边部分。
public string LeftExpression { get; set; }
例子
显示如何使用 SKIPIF 字段在邮件合并中跳过页面。
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 行的数据源,其中一行将“John Doe”作为“Name”列的值。
// 因为 SKIPIF 字段将被该值触发一次,所以我们的邮件合并的输出将有 2 页而不是 3 页。
// 在第 1 页上,MERGESEQ 和 MERGEREC 字段都将显示“1”。
// 在第 2 页上,MERGEREC 字段将显示“3”,MERGESEQ 字段将显示“2”。
DataTable table = new DataTable("Employees");
table.Columns.Add("Name");
table.Rows.Add(new[] { "Jane Doe" });
table.Rows.Add(new[] { "John Doe" });
table.Rows.Add(new[] { "Joe Bloggs" });
doc.MailMerge.Execute(table);
doc.Save(ArtifactsDir + "Field.MERGEREC.MERGESEQ.docx");
显示如何使用 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 行的数据源,其中一行将“John Doe”作为“Name”列的值。
// 因为 SKIPIF 字段将被该值触发一次,所以我们的邮件合并的输出将有 2 页而不是 3 页。
// 在第 1 页上,MERGESEQ 和 MERGEREC 字段都将显示“1”。
// 在第 2 页上,MERGEREC 字段将显示“3”,MERGESEQ 字段将显示“2”。
DataTable table = new DataTable("Employees");
table.Columns.Add("Name");
table.Rows.Add(new[] { "Jane Doe" });
table.Rows.Add(new[] { "John Doe" });
table.Rows.Add(new[] { "Joe Bloggs" });
doc.MailMerge.Execute(table);
doc.Save(ArtifactsDir + "Field.MERGEREC.MERGESEQ.docx");
也可以看看
- class FieldSkipIf
- 命名空间 Aspose.Words.Fields
- 部件 Aspose.Words