MappedDataFieldCollection
MappedDataFieldCollection class
Позволяет автоматически сопоставлять имена полей в вашем источнике данных с именами полей слияния почты в документе.
Чтобы узнать больше, посетитеСлияние почты и отчетность статья документации.
public class MappedDataFieldCollection : IEnumerable<KeyValuePair<string, string>>
Характеристики
Имя | Описание |
---|---|
Count { get; } | Получает количество элементов, содержащихся в коллекции. |
Item { get; set; } | Получает или задает имя поля в источнике данных, связанном с указанным полем слияния почты. |
Методы
Имя | Описание |
---|---|
Add(string, string) | Добавляет новое сопоставление полей. |
Clear() | Удаляет все элементы из коллекции. |
ContainsKey(string) | Определяет, существует ли в коллекции сопоставление из указанного поля документа. |
ContainsValue(string) | Определяет, существует ли в коллекции сопоставление из указанного поля в источнике данных. |
GetEnumerator() | Возвращает объект перечислителя словаря, который можно использовать для перебора всех элементов коллекции. |
Remove(string) | Удаляет сопоставление полей. |
Примечания
Это реализовано как набор строковых ключей в строковых значениях. Ключи — это имена полей слияния почты в документе, а значения — это имена полей в вашем источнике данных.
Примеры
Показывает, как сопоставить столбцы данных и поля MERGEFIELD с разными именами, чтобы данные передавались между ними во время слияния почты.
public void MappedDataFieldCollection()
{
Document doc = CreateSourceDocMappedDataFields();
DataTable dataTable = CreateSourceTableMappedDataFields();
// В таблице есть столбец с именем «Столбец2», но полей MERGEFIELD с таким именем нет.
// Кроме того, у нас есть поле MERGEFIELD с именем «Столбец3», но в источнике данных нет столбца с таким именем.
// Если данные из «Столбца2» подходят для поля MERGEFILD «Столбец3»,
// мы можем сопоставить имя этого столбца с MERGEFIELD в паре ключ/значение "MappedDataFields".
MappedDataFieldCollection mappedDataFields = doc.MailMerge.MappedDataFields;
// Мы можем связать имя столбца источника данных с именем MERGEFIELD следующим образом.
mappedDataFields.Add("MergeFieldName", "DataSourceColumnName");
// Свяжите столбец источника данных с именем «Столбец2» с MERGEFIELD с именем «Столбец3».
mappedDataFields.Add("Column3", "Column2");
// Имя MERGEFIELD является «ключом» к имени соответствующего столбца источника данных «значение».
Assert.AreEqual("DataSourceColumnName", mappedDataFields["MergeFieldName"]);
Assert.True(mappedDataFields.ContainsKey("MergeFieldName"));
Assert.True(mappedDataFields.ContainsValue("DataSourceColumnName"));
// Теперь, если мы запустим это слияние почты, поля MERGEFIELD «Столбец3» будут брать данные из «Столбца2» таблицы.
doc.MailMerge.Execute(dataTable);
doc.Save(ArtifactsDir + "MailMerge.MappedDataFieldCollection.docx");
// Мы можем перебирать элементы в этой коллекции.
Assert.AreEqual(2, mappedDataFields.Count);
using (IEnumerator<KeyValuePair<string, string>> enumerator = mappedDataFields.GetEnumerator())
while (enumerator.MoveNext())
Console.WriteLine(
$"Column named {enumerator.Current.Value} is mapped to MERGEFIELDs named {enumerator.Current.Key}");
// Мы также можем удалять элементы из коллекции.
mappedDataFields.Remove("MergeFieldName");
Assert.False(mappedDataFields.ContainsKey("MergeFieldName"));
Assert.False(mappedDataFields.ContainsValue("DataSourceColumnName"));
mappedDataFields.Clear();
Assert.AreEqual(0, mappedDataFields.Count);
}
/// <summary>
/// Создадим документ с двумя MERGEFIELD, один из которых не имеет
/// соответствующий столбец в таблице данных из метода ниже.
/// </summary>
private static Document CreateSourceDocMappedDataFields()
{
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
builder.InsertField(" MERGEFIELD Column1");
builder.Write(", ");
builder.InsertField(" MERGEFIELD Column3");
return doc;
}
/// <summary>
/// Создадим таблицу данных с двумя столбцами, один из которых не имеет
/// соответствующее MERGEFIELD в исходном документе из метода выше.
/// </summary>
private static DataTable CreateSourceTableMappedDataFields()
{
DataTable dataTable = new DataTable("MyTable");
dataTable.Columns.Add("Column1");
dataTable.Columns.Add("Column2");
dataTable.Rows.Add(new object[] { "Value1", "Value2" });
return dataTable;
}
Смотрите также
- пространство имен Aspose.Words.MailMerging
- сборка Aspose.Words