Работа со стилями и темами
The StyleCollection Класс используется для управления встроенными и применения пользовательских настроек к стилям.
Доступ к стилям
Вы можете получить набор стилей, определенных в документе, используя Document.styles собственность. Эта коллекция содержит как встроенные, так и пользовательские стили в документе. Определенный стиль может быть получен по его имени / алии, идентификатору стиля или индексу. Следующий пример кода показывает, как получить доступ к набору стилей, определенных в документе.
Как извлечь контент на основе стилей
На простом уровне извлечение контента на основе стилей из документа Word может быть полезным для идентификации, перечисления и подсчета абзацев и прогонов текста, отформатированного в определенном стиле. Например, вам может потребоваться определить конкретные виды контента в документе, такие как примеры, заголовки, ссылки, ключевые слова, имена фигур и тематические исследования.
Чтобы сделать это еще на несколько шагов, можно также использовать структуру документа, определяемую используемыми стилями, для переназначения документа для другого вывода, такого как HTML. Именно так строится документация Aspose, ставя Aspose.Words На тест. Инструмент, построенный с использованием Aspose.Words берет исходные документы Word и разделяет их на темы на определенных уровнях заголовков. XML-файл создается с использованием Aspose.Words Используется для построения дерева навигации, которое можно увидеть слева. А потом Aspose.Words Преобразует каждую тему в HTML.
Решение для извлечения текста, отформатированного с определенными стилями в документе Word, обычно экономично и просто. Aspose.Words.
Решение
Чтобы показать, как легко Aspose.Words обрабатывает извлечение контента на основе стилей, давайте рассмотрим пример. В этом примере мы собираемся извлечь текст, отформатированный с определенным стилем абзаца и стилем символа из образца документа Word. На высоком уровне это будет включать:
- Открытие документа Word с использованием Document класс.
- Получение сборников всех абзацев и всех строк в документе.
- Выбор только необходимых абзацев и прогонов. В частности, мы получим текст, отформатированный в стиле абзаца “Глава 1” и стиле персонажа “Интенсивный акцент” из этого образца документа Word.
В этом примере документа текст, отформатированный в стиле абзаца заголовка 1, представляет собой “Insert Tab”, “Quick Styles” и “Theme”, а текст, отформатированный в стиле символов “Intense emphasis”, представляет собой несколько экземпляров синего, курсивного, смелого текста, такого как “галереи” и “общий вид”.
Кодекс
Реализация стилистического запроса довольно проста в Aspose.Words Модель объекта документа, так как она просто использует инструменты, которые уже существуют. Для этого решения реализованы два класса методов:
- Источник:_by_style_name - Этот метод извлекает массив из тех пунктов в документе, которые имеют определенное название стиля.
- Runs_by_style_name - Этот метод извлекает множество тех заданий в документе, которые имеют определенное название стиля. Оба эти метода очень похожи, единственными отличиями являются типы узлов и представление информации о стиле в абзаце и узлах запуска. Вот вам реализация
paragraphs_by_style_name
: Ниже приведены примеры всех абзацев, отформатированных в указанном стиле.
Эта реализация также использует Document.get_child_nodes Методика Document класс, который возвращает совокупность всех узлов с указанным типом, которая в данном случае во всех пунктах.
Отметим, что второй параметр Document.get_child_nodes метод устанавливается True
. Это заставляет Document.get_child_nodes метод рекурсивного выбора из всех узлов ребенка, а не выбора только ближайших детей.
Также стоит отметить, что сбор абзацев не создает непосредственных накладных расходов, потому что абзацы загружаются в эту коллекцию только при доступе к элементам в них. Затем все, что вам нужно сделать, это пройтись по коллекции, используя стандартный для каждого оператора и добавить абзацы, которые имеют указанный стиль, к массиву paragraphs_with_style. The Paragraph
Название стиля можно найти в Style.name имуществом, Paragraph.paragraph_format объект. Осуществление Runs_by_style_name Это почти то же самое, хотя мы используем NodeType.RUN для извлечения запущенных узлов. The Font.style свойство а Run объект используется для доступа к информации о стиле в Run Узлы. Ниже приведен пример всех прогонов, отформатированных с указанным стилем.
Когда оба запроса реализованы, все, что вам нужно сделать, это передать объект документа и указать названия стилей контента, который вы хотите получить: Ниже приведен пример выполнения запросов и отображения результатов. Вы можете скачать файл шаблона этого примера из здесь.
Конечный результат
Когда все будет сделано, запуск образца будет отображать следующий вывод:
Как видите, это очень простой пример, показывающий количество и текст собранных абзацев и запускается в образце документа Word.
Все стили из шаблона
Бывают случаи, когда хочется скопировать все стили из одного документа в другой. Вы можете использовать Document.copy_styles_from_template метод копирования стилей из указанного шаблона в документ. Когда стили копируются из шаблона в документ, аналогичные стили в документе переопределяются, чтобы соответствовать описаниям стилей в шаблоне. Уникальные стили из шаблона копируются в документ. Уникальные стили в документе остаются нетронутыми. бытьlow code Пример показывает, как копировать стили из одного документа в другой.
Как манипулировать Тематические свойства
Мы добавили основные API в Aspose.Words Доступ к свойствам темы документа. На данный момент это API Включает следующие общественные объекты:
Вот как вы можете получить свойства темы:
И вот как вы можете установить свойства темы: