Укажите параметры загрузки
При загрузке документа вы можете задать некоторые дополнительные свойства. Aspose.Words предоставляет вам класс LoadOptions, который позволяет более точно управлять процессом загрузки. У некоторых форматов загрузки есть соответствующий класс, который содержит параметры загрузки для этого формата загрузки, например, есть PdfLoadOptions для загрузки в формат PDF или TxtLoadOptions для загрузки в формат TXT. В этой статье приведены примеры работы с параметрами класса LoadOptions.
Установите версию Microsoft Word, чтобы изменить внешний вид
В разных версиях приложения Microsoft Word документы могут отображаться по-разному. Например, существует хорошо известная проблема с документами OOXML, такими как DOCX или DOTX, созданными с помощью WPS Office. В таких случаях важные элементы разметки документа могут отсутствовать или интерпретироваться по-другому, что приводит к тому, что в Microsoft Word 2019 такой документ отображается иначе, чем в Microsoft Word 2010.
По умолчанию Aspose.Words открывает документы по правилам Microsoft Word 2019 года. Если вам нужно, чтобы загрузка документов происходила так, как это происходило бы в одной из предыдущих версий приложения Microsoft Word, вам следует явно указать желаемую версию, используя свойство MswVersion класса LoadOptions.
В следующем примере кода показано, как установить версию Microsoft Word с параметрами загрузки:
Установите языковые настройки, чтобы изменить внешний вид
Особенности отображения документа в Microsoft Word зависят не только от версии приложения и значения свойства MswVersion, но и от языковых настроек. Microsoft Word документы могут отображаться по-разному в зависимости от настроек диалогового окна “Языковые настройки Office”, которые можно найти в разделе “Файл → Параметры → Язык”. С помощью этого диалогового окна пользователь может выбрать, например, основной язык, языки проверки подлинности, языки отображения и так далее. Aspose.Words предоставляет свойство LanguagePreferences в качестве эквивалента этого диалогового окна. Если выходные данные Aspose.Words отличаются от выходных данных Microsoft Word, установите соответствующее значение для EditingLanguage – это может улучшить качество выходного документа.
В следующем примере кода показано, как задать японский язык как EditingLanguage:
Используйте WarningCallback для устранения проблем при загрузке документа
Некоторые документы могут быть повреждены, содержать недопустимые записи или содержать функции, которые в настоящее время не поддерживаются Aspose.Words. Если вы хотите узнать о проблемах, возникших при загрузке документа, Aspose.Words предоставляет интерфейс IWarningCallback.
В следующем примере кода показана реализация интерфейса IWarningCallback:
Чтобы получить информацию обо всех проблемах во время загрузки, используйте свойство WarningCallback.
В следующем примере кода показано, как использовать это свойство:
Используйте ResourceLoadingCallback для управления загрузкой внешних ресурсов
Документ может содержать внешние ссылки на изображения, расположенные где-либо на локальном диске, в сети или в Интернете. Aspose.Words такие изображения автоматически загружаются в документ, но бывают ситуации, когда этот процесс необходимо контролировать. Например, чтобы решить, действительно ли нам нужно загружать определенное изображение или, возможно, пропустить его. Параметр загрузки ResourceLoadingCallback позволяет вам управлять этим.
В следующем примере кода показана реализация интерфейса IResourceLoadingCallback:
В следующем примере кода показано, как использовать свойство ResourceLoadingCallback:
Используйте TempFolder, чтобы избежать исключения из памяти
Aspose.Words поддерживает чрезвычайно большие документы, содержащие тысячи страниц с богатым содержанием. Загрузка таких документов может потребовать значительных затрат RAM. В процессе загрузки Aspose.Words требуется еще больше памяти для хранения временных структур, используемых для синтаксического анализа документа.
Если при загрузке документа у вас возникла проблема с исключением “Нехватка памяти”, попробуйте использовать свойство TempFolder. В этом случае Aspose.Words сохранит некоторые данные во временных файлах вместо памяти, и это может помочь избежать такого исключения.
В следующем примере кода показано, как установить TempFolder:
Задайте кодировку явно
Большинство современных форматов документов хранят свое содержимое в Юникоде и не требуют специальной обработки. С другой стороны, все еще существует множество документов, в которых используется некоторая кодировка, предшествовавшая Юникоду, и иногда либо отсутствует информация о кодировке, либо она даже не поддерживается по своей природе. Aspose.Words пытается автоматически определить соответствующую кодировку по умолчанию, но в редких случаях вам может потребоваться использовать кодировку, отличную от той, которая определяется нашим алгоритмом распознавания кодировок. В этом случае используйте свойство Encoding, чтобы получить или задать кодировку.
В следующем примере кода показано, как настроить кодировку таким образом, чтобы она переопределяла автоматически выбранную кодировку:
Загружайте зашифрованные документы
Вы можете загружать документы Word, зашифрованные паролем. Для этого используйте специальный конструктор overload, который принимает объект LoadOptions. Этот объект содержит свойство Password, которое определяет строку пароля.
В следующем примере кода показано, как загрузить документ, зашифрованный паролем:
Если вы заранее не знаете, зашифрован ли файл, вы можете использовать класс FileFormatUtil, который предоставляет служебные методы для работы с форматами файлов, такие как определение формата файла или преобразование расширений файлов в/из перечислений форматов файлов. Чтобы определить, зашифрован ли документ и требуется ли пароль для его открытия, используйте свойство IsEncrypted.
В следующем примере кода показано, как проверить, зашифрован OpenDocument или нет: