ContentStatus
Содержание
[
Скрывать
]BuiltInDocumentProperties.ContentStatus property
Получает или задает статус содержимого документа.
public string ContentStatus { get; set; }
Примеры
Показывает, как работать со свойствами документа в категории «Содержимое».
public void Content()
{
Document doc = new Document(MyDir + "Paragraphs.docx");
BuiltInDocumentProperties properties = doc.BuiltInDocumentProperties;
// Используя встроенные свойства,
// мы можем обрабатывать статистику документа, такую как количество слов/страниц/символов, как метаданные, которые можно просмотреть, не открывая документ
// Доступ к этим свойствам можно получить, щелкнув правой кнопкой мыши файл в проводнике Windows и перейдя в Свойства > Подробности > Содержимое
// Если мы хотим отобразить эти данные внутри документа, мы можем использовать такие поля, как NUMPAGES, NUMWORDS, NUMCHARS и т. д.
// Кроме того, эти значения можно просмотреть в Microsoft Word, выбрав Файл > Свойства > Дополнительные свойства > Статистика
// Количество страниц: свойство PageCount показывает количество страниц в реальном времени, а его значение можно присвоить свойству Pages
// Свойство «Страницы» хранит количество страниц документа.
Assert.AreEqual(6, properties.Pages);
// Встроенные свойства «Слова», «Символы» и «СимволыСПробелами» также отображают различную статистику документа,
// но нам нужно вызвать метод «UpdateWordCount» для всего документа, прежде чем мы сможем ожидать, что они будут содержать точные значения.
doc.UpdateWordCount();
Assert.AreEqual(1035, properties.Words);
Assert.AreEqual(6026, properties.Characters);
Assert.AreEqual(7041, properties.CharactersWithSpaces);
// Подсчитываем количество строк в документе, а затем присваиваем результат встроенному свойству «Строки».
LineCounter lineCounter = new LineCounter(doc);
properties.Lines = lineCounter.GetLineCount();
Assert.AreEqual(142, properties.Lines);
// Назначаем количество узлов абзацев в документе встроенному свойству «Абзацы».
properties.Paragraphs = doc.GetChildNodes(NodeType.Paragraph, true).Count;
Assert.AreEqual(29, properties.Paragraphs);
// Получите оценку размера файла нашего документа с помощью встроенного свойства «Байты».
Assert.AreEqual(20310, properties.Bytes);
// Задайте другой шаблон для нашего документа, а затем вручную обновите встроенное свойство «Шаблон», чтобы отразить это изменение.
doc.AttachedTemplate = MyDir + "Business brochure.dotx";
Assert.AreEqual("Normal", properties.Template);
properties.Template = doc.AttachedTemplate;
// «ContentStatus» — это описательное встроенное свойство.
properties.ContentStatus = "Draft";
// При сохранении встроенное свойство «ContentType» будет содержать MIME-тип выходного формата сохранения.
Assert.AreEqual(string.Empty, properties.ContentType);
// Если документ содержит ссылки и все они актуальны, мы можем установить свойство «LinksUpToDate» в значение «true».
Assert.False(properties.LinksUpToDate);
doc.Save(ArtifactsDir + "DocumentProperties.Content.docx");
}
/// <summary>
/// Подсчитывает количество строк в документе.
/// Проходит по дереву сущностей макета документа при построении,
/// подсчет сущностей типа «Строка», которые также содержат реальный текст.
/// </summary>
private class LineCounter
{
public LineCounter(Document doc)
{
mLayoutEnumerator = new LayoutEnumerator(doc);
CountLines();
}
public int GetLineCount()
{
return mLineCount;
}
private void CountLines()
{
do
{
if (mLayoutEnumerator.Type == LayoutEntityType.Line)
{
mScanningLineForRealText = true;
}
if (mLayoutEnumerator.MoveFirstChild())
{
if (mScanningLineForRealText && mLayoutEnumerator.Kind.StartsWith("TEXT"))
{
mLineCount++;
mScanningLineForRealText = false;
}
CountLines();
mLayoutEnumerator.MoveParent();
}
} while (mLayoutEnumerator.MoveNext());
}
private readonly LayoutEnumerator mLayoutEnumerator;
private int mLineCount;
private bool mScanningLineForRealText;
}
Смотрите также
- class BuiltInDocumentProperties
- пространство имен Aspose.Words.Properties
- сборка Aspose.Words