OdsoDataSourceType

OdsoDataSourceType enumeration

Указывает тип внешнего источника данных, к которому будет осуществляться подключение, как часть информации о подключении ODSO.

public enum OdsoDataSourceType

Ценности

ИмяЦенностьОписание
Text0Указывает, что данный документ был подключен к текстовому файлу. Возможно wdMergeSubTypeOther.
Database1Указывает, что данный документ подключен к базе данных. Возможно wdMergeSubTypeAccess.
AddressBook2Указывает, что данный документ был подключен к адресной книге контактов. Возможно wdMergeSubTypeOAL.
Document13Указывает, что данный документ был подключен к другому формату документа, поддерживаемому создающим приложением. Возможно wdMergeSubTypeOLEDBWord.
Document24Указывает, что данный документ был связан с другим форматом документа, поддерживаемым создающим приложением. Возможно, wdMergeSubTypeWorks.
Native5Указывает, что данный документ был связан с другим форматом документа, являющимся собственным для создающего приложения. Возможно wdMergeSubTypeOLEDBText
Email6Указывает, что данный документ был подключен к приложению электронной почты. Возможно wdMergeSubTypeOutlook.
None7Тип внешнего источника данных не указан. Возможно wdMergeSubTypeWord.
Legacy8Указывает, что данный документ был подключен к устаревшему формату документа, поддерживаемому производящим приложением Возможно wdMergeSubTypeWord2000.
Master9Указывает, что данный документ подключен к источнику данных, который объединяет другие источники данных.
Default7РавноNone .

Примечания

Спецификация OOXML для этого перечисления очень расплывчата. Я предполагаю, что оно может соответствовать перечислению WdMergeSubType http://msdn.microsoft.com/en-us/library/bb237801.aspx.

Примеры

Показывает, как выполнить слияние почты с данными из объекта источника данных Office.

Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);

builder.Write("Dear ");
builder.InsertField("MERGEFIELD FirstName", "<FirstName>");
builder.Write(" ");
builder.InsertField("MERGEFIELD LastName", "<LastName>");
builder.Writeln(": ");
builder.InsertField("MERGEFIELD Message", "<Message>");

// Создаем источник данных в виде ASCII-файла с символом "|"
// действует как разделитель, который разделяет столбцы. Первая строка содержит имена трех столбцов,
// и каждая последующая строка — это строка с соответствующими им значениями.
string[] lines = { "FirstName|LastName|Message",
    "John|Doe|Hello! This message was created with Aspose Words mail merge." };
string dataSrcFilename = ArtifactsDir + "MailMerge.MailMergeSettings.DataSource.txt";

File.WriteAllLines(dataSrcFilename, lines);

MailMergeSettings settings = doc.MailMergeSettings;
settings.MainDocumentType = MailMergeMainDocumentType.MailingLabels;
settings.CheckErrors = MailMergeCheckErrors.Simulate;
settings.DataType = MailMergeDataType.Native;
settings.DataSource = dataSrcFilename;
settings.Query = "SELECT * FROM " + doc.MailMergeSettings.DataSource;
settings.LinkToQuery = true;
settings.ViewMergedData = true;

Assert.AreEqual(MailMergeDestination.Default, settings.Destination);
Assert.False(settings.DoNotSupressBlankLines);

Odso odso = settings.Odso;
odso.DataSource = dataSrcFilename;
odso.DataSourceType = OdsoDataSourceType.Text;
odso.ColumnDelimiter = '|';
odso.FirstRowContainsColumnNames = true;

Assert.AreNotSame(odso, odso.Clone());
Assert.AreNotSame(settings, settings.Clone());

 // При открытии этого документа в Microsoft Word будет выполнено слияние почты перед отображением содержимого.
doc.Save(ArtifactsDir + "MailMerge.MailMergeSettings.docx");

Смотрите также