Версию Microsoft Visual C# для .NET этой статьи см. в разделе 316384.
Сведения о версии этой статьи Microsoft Visual Basic 6.0 см. в разделе 313193.
Аннотация
В этой пошаговой статье описывается создание нового документа в Word с помощью службы автоматизации из Visual Basic .NET.
Пример кода
В примере кода в этой статье показано, как сделать следующее:
-
Вставка абзацев с текстом и форматированием.
-
Просмотр и изменение различных диапазонов в документе.
-
Вставка таблиц, форматирование таблиц и заполнение таблиц данными.
-
Добавление диаграммы.
Чтобы создать документ Word с помощью службы автоматизации из Visual Basic .NET, выполните следующие действия.
-
Запустите Microsoft Visual Studio .NET. В меню Файл выберите пункт Создать, а затем — Проект. В разделе Типы проектов выберите Проекты Visual Basic, а затем — Приложение Windows в разделе Шаблоны. Форма Form1 создается по умолчанию.
-
Добавьте ссылку на библиотеку объектов Microsoft Word. Для этого выполните следующие действия:
-
В меню Проект щелкните Добавить ссылку.
-
На вкладке COM найдите библиотеку объектов Microsoft Word и нажмите кнопку Выбрать.
Обратите внимание, что Microsoft Office 2003 и более поздние версии Office включают основные сборки взаимодействия (PIA). Microsoft Office XP не включает piA, но их можно скачать.
-
Нажмите кнопку ОК в диалоговом окне Добавление ссылок, чтобы принять выбранные значения. Если появится запрос на создание оболочек для выбранных библиотек, нажмите кнопку Да.
-
-
В меню Вид выберите Панель элементов, чтобы отобразить панель элементов, а затем добавьте кнопку в Form1.
-
Дважды щелкните Button1. Откроется окно кода для формы.
-
В окне кода замените приведенный ниже код.
Private Sub Button1_Click(ByVal sender As System.Object, _ ByVal e As System.EventArgs) Handles Button1.Click End Sub
С:
Private Sub Button1_Click(ByVal sender As System.Object, _ ByVal e As System.EventArgs) Handles Button1.Click Dim oWord As Word.Application Dim oDoc As Word.Document Dim oTable As Word.Table Dim oPara1 As Word.Paragraph, oPara2 As Word.Paragraph Dim oPara3 As Word.Paragraph, oPara4 As Word.Paragraph Dim oRng As Word.Range Dim oShape As Word.InlineShape Dim oChart As Object Dim Pos As Double 'Start Word and open the document template. oWord = CreateObject("Word.Application") oWord.Visible = True oDoc = oWord.Documents.Add 'Insert a paragraph at the beginning of the document. oPara1 = oDoc.Content.Paragraphs.Add oPara1.Range.Text = "Heading 1" oPara1.Range.Font.Bold = True oPara1.Format.SpaceAfter = 24 '24 pt spacing after paragraph. oPara1.Range.InsertParagraphAfter() 'Insert a paragraph at the end of the document. '** endofdoc is a predefined bookmark. oPara2 = oDoc.Content.Paragraphs.Add(oDoc.Bookmarks.Item("endofdoc").Range) oPara2.Range.Text = "Heading 2" oPara2.Format.SpaceAfter = 6 oPara2.Range.InsertParagraphAfter() 'Insert another paragraph. oPara3 = oDoc.Content.Paragraphs.Add(oDoc.Bookmarks.Item("endofdoc").Range) oPara3.Range.Text = "This is a sentence of normal text. Now here is a table:" oPara3.Range.Font.Bold = False oPara3.Format.SpaceAfter = 24 oPara3.Range.InsertParagraphAfter() 'Insert a 3 x 5 table, fill it with data, and make the first row 'bold and italic. Dim r As Integer, c As Integer oTable = oDoc.Tables.Add(oDoc.Bookmarks.Item("endofdoc").Range, 3, 5) oTable.Range.ParagraphFormat.SpaceAfter = 6 For r = 1 To 3 For c = 1 To 5 oTable.Cell(r, c).Range.Text = "r" & r & "c" & c Next Next oTable.Rows.Item(1).Range.Font.Bold = True oTable.Rows.Item(1).Range.Font.Italic = True 'Add some text after the table. 'oTable.Range.InsertParagraphAfter() oPara4 = oDoc.Content.Paragraphs.Add(oDoc.Bookmarks.Item("endofdoc").Range) oPara4.Range.InsertParagraphBefore() oPara4.Range.Text = "And here's another table:" oPara4.Format.SpaceAfter = 24 oPara4.Range.InsertParagraphAfter() 'Insert a 5 x 2 table, fill it with data, and change the column widths. oTable = oDoc.Tables.Add(oDoc.Bookmarks.Item("endofdoc").Range, 5, 2) oTable.Range.ParagraphFormat.SpaceAfter = 6 For r = 1 To 5 For c = 1 To 2 oTable.Cell(r, c).Range.Text = "r" & r & "c" & c Next Next oTable.Columns.Item(1).Width = oWord.InchesToPoints(2) 'Change width of columns 1 & 2 oTable.Columns.Item(2).Width = oWord.InchesToPoints(3) 'Keep inserting text. When you get to 7 inches from top of the 'document, insert a hard page break. Pos = oWord.InchesToPoints(7) oDoc.Bookmarks.Item("endofdoc").Range.InsertParagraphAfter() Do oRng = oDoc.Bookmarks.Item("endofdoc").Range oRng.ParagraphFormat.SpaceAfter = 6 oRng.InsertAfter("A line of text") oRng.InsertParagraphAfter() Loop While Pos >= oRng.Information(Word.WdInformation.wdVerticalPositionRelativeToPage) oRng.Collapse(Word.WdCollapseDirection.wdCollapseEnd) oRng.InsertBreak(Word.WdBreakType.wdPageBreak) oRng.Collapse(Word.WdCollapseDirection.wdCollapseEnd) oRng.InsertAfter("We're now on page 2. Here's my chart:") oRng.InsertParagraphAfter() 'Insert a chart and change the chart. oShape = oDoc.Bookmarks.Item("endofdoc").Range.InlineShapes.AddOLEObject( _ ClassType:="MSGraph.Chart.8", FileName _ :="", LinkToFile:=False, DisplayAsIcon:=False) oChart = oShape.OLEFormat.Object oChart.charttype = 4 'xlLine = 4 oChart.Application.Update() oChart.Application.Quit() 'If desired, you can proceed from here using the Microsoft Graph 'Object model on the oChart object to make additional changes to the 'chart. oShape.Width = oWord.InchesToPoints(6.25) oShape.Height = oWord.InchesToPoints(3.57) 'Add text after the chart. oRng = oDoc.Bookmarks.Item("endofdoc").Range oRng.InsertParagraphAfter() oRng.InsertAfter("THE END.") 'All done. Close this form. Me.Close() End Sub
-
Добавьте следующий код в начало Form1.vb:
Imports Word = Microsoft.Office.Interop.Word
-
Нажмите клавишу F5, чтобы выполнить сборку и запуск программы.
После завершения кода изучите документ, созданный для вас. Документ содержит две страницы отформатированных абзацев, таблиц и диаграммы.
Использование шаблона
Если вы используете службу автоматизации для создания документов в общем формате, вы можете начать процесс с нового документа, основанного на предварительно отформатованном шаблоне. Использование шаблона с клиентом службы автоматизации Word имеет два существенных преимущества по сравнению с созданием документа из ничего:
-
Вы можете иметь больший контроль над форматированием и размещением объектов в документах.
-
Вы можете создавать документы с меньшим количеством кода.
С помощью шаблона можно точно настроить размещение таблиц, абзацев и других объектов в документе, а также включить форматирование этих объектов. С помощью службы автоматизации можно создать новый документ на основе шаблона с таким кодом:
oWord.Documents.Add "<Path to your template>MyTemplate.dot"
В шаблоне можно определить закладки, чтобы клиент службы автоматизации смог заполнить текст переменной в определенном расположении в документе следующим образом:
oDoc.Bookmarks.Item("MyBookmark").Range.Text = "Some Text Here"
Еще одно преимущество использования шаблона заключается в том, что вы можете создавать и хранить стили форматирования, которые необходимо применять во время выполнения, следующим образом:
oDoc.Bookmarks.Item("MyBookmark").Range.Style = "MyStyle"
-или-
oWord.Selection.Style = "MyStyle"
Ссылки
Чтобы получить дополнительные сведения об использовании Visual Basic .NET для автоматизации Microsoft Word, щелкните следующий номер статьи, чтобы просмотреть статью в базе знаний Майкрософт:
301656 Автоматизация Word для выполнения слияния из Visual Basic .NET
Нужна дополнительная помощь?
На прошлой неделе постоянный читатель сайта задал мне вопрос об автоматизации своей работы с редактором Word. Потребовалось некоторое время, чтобы найти ответ. И в результате появилась очередная статья в онлайн-журнале «Компьютерра».
Теперь публикую и на сайте.
Вопрос:
Я знаю, что в Word есть функция, когда какая-либо комбинация клавиш меняется на текст, который я заранее ввел. Это удобно, если одна и та же фраза или слово много раз повторяется в документе. Мне казалось, что это в «Автозамене», но у меня ничего не получилось. Подскажите, пожалуйста правильный ответ.
Действительно, такая возможность есть. Правда, для того чтобы назначить какому-либо часто повторяющемуся словосочетанию «горячую клавишу» придется немного пощелкать мышкой.
Во-первых, определитесь со словосочетанием, которое вы постоянно используете в своих текстах. Возможно, оно у вас не одно.
Во-вторых, занесите это словосочетание в Автотекст
Автотекст. Текстовые или графические элементы, которые можно многократно использовать в документах, например стандартные пункты договора или список отпускаемых товаров. Каждый выделенный фрагмент текста или графический объект сохраняется в виде элемента автотекста и получает свое уникальное имя. (из Справки Word)
Для этого создайте пустой документ и напечатайте ваше словосочетание. Затем выделите его и нажмите сочетание клавиш «Alt+F3». Появится подтверждающее окно Создание элемента автотекста (Create AutoText) с вашим словосочетанием, которое вы можете отредактировать или ввести иное словосочетание.
Нажмите кнопку OK для подтверждения. Все, ваше словосочетание занесено в Автотекст.
Создать новый элемент автотекста можно и другим, более трудоемким способом — через меню Вставка (Insert), в котором вам следует выбрать из подменю команды Автотекст (AutoText) такую же одноименную команду. Откроется окно Автозамена (AutoCorrect) как раз на вкладке Автотекст.
В поле шмя элемента (Enter AutoText entries here) введите вашу часто повторяющуюся фразу и нажмите кнопку Добавить (Add).
Итак, фраза для автоматической вставки в ваш документ создана, теперь необходимо присвоить ей какое-нибудь сочетание клавиш, используя которое вы легко и быстро добавите вашу фразу в документ.
Для этого:
- Выберите из меню Сервис (Tools) команду Настройка (Customize). Откроется диалоговое окно, внизу которого вы увидите кнопку Клавиатура (Keyboard). Нажмите ее и перед вами появится новое окно Настройка клавиатуры (Customize Keyboard), как на скриншоте ниже:
- В левой области окна выберите ((Выбрать — означает щелкнуть мышкой на нужном элементе, который сразу станет подсвеченным)) категорию Автотекст (AutoText) — она находится в самом низу категорий — а справа в поле Автотекст (AutoText) выберите вашу фразу/словосочетание.
- Чуть ниже, в поле Новое сочетание клавиш (Press new shortcut key), введите ваше сочетание клавиш, используя функциональные клавиши: Ctrl, Shift или Alt. Причем клавиша Shift может присутствовать только в сочетании с одной из двух своих подруг: Ctrl или Alt.
Обратите внимание: если выбранное вами сочетание клавиш («горячие клавиши») уже используются иным элементом автотекста, то ниже вы увидите неприметное поле Текущее назначение и тот элемент автотекста, за которым зарезервированы эти горячие клавиши. Просто выберите другое сочетание клавиш. Для этого достаточно очистить поле, нажав на клавитуре клавишу Delete и ввести новый вариант.
- Теперь осталось нажать кнопку Назначить (Assign) и закрыть все окна.
Таким образом, выполнив эти шаги, вы существенно увеличите эффективность своей работы в текстовом редакторе Word, и, быть может, поднимите свой авторитет среди коллег. Ведь они-то так не могут!
Часть 1. Microsoft Word и Microsoft Excel
Коротко об автоматизации
VBA и средства разработки контроллеров автоматизации
Объектные модели Microsoft Office
Общие принципы создания контроллеров автоматизации
Автоматизация Microsoft Word
Программные идентификаторы и объектная модель Microsoft Word
Создание и открытие документов Microsoft Word
Сохранение, печать и закрытие документов Microsoft Word
Вставка текста и объектовв документ и форматирование текста
Перемещение курсора по тексту
Создание таблиц
Обращение к свойствам документа
Автоматизация Microsoft Excel
Программные идентификаторы и объектная модель Microsoft Excel
Запуск Microsoft Excel, создание и открытие рабочих книг
Сохранение, печать и закрытие рабочих книг Microsoft Excel
Обращение к листам и ячейкам
Создание
диаграмм
Настоящая статья посвящена теме, может быть, и не новой,
но, как показывают письма читателей, по-прежнему актуальной — автоматизации
приложений Microsoft Office. Многие разработчики в процессе работы над своими
проектами (неважно, с помощью какого средства разработки — Delphi, C++Builder,
Visual Basic…) нередко применяют сервисы, предоставляемые Microsoft Office,
например построение сводных таблиц и диаграмм с помощью Microsoft Excel, генерацию
и печать документов с помощью Microsoft Word и т.д. Нередко пользователи, привыкшие
использовать приложения Microsoft Office в повседневной работе, сами настаивают
на применении в приложениях таких сервисов либо просто на сохранении отчетов
и других документов в одном из форматов Microsoft Office. Отметим, что потенциальные пожелания подобного рода
компанией Microsoft учтены достаточно давно — практически все, что в состоянии
сделать пользователь любого приложения Microsoft Office с помощью меню, клавиатуры
и инструментальной панели, может быть произведено и автоматически, то есть либо
из VBA-программы, либо из приложения, созданного с помощью одного из средств
разработки. Иными словами, приложения Microsoft Office являются программируемыми.
Программируемость в общем случае означает возможность
управления данным приложением с помощью макроязыков либо с помощью других приложений.
Все компоненты Microsoft Office поддерживают один и тот же макроязык: Visual
Basic for Applications (VBA), позволяющий создавать приложения непосредственно
внутри документов Office (это называется «решения на базе Microsoft Office»).
Управление же компонентами Office из других приложений осуществляется с помощью
автоматизации (Automation, ранее — OLE Automation) — все приложения
Microsoft Office являются серверами автоматизации (или COM-серверами).
Для создания таких приложений пригодны любые средства
разработки, позволяющие создавать контроллеры автоматизации (COM-клиенты).
Наиболее часто для этой цели используется Visual Basic,
но это могут быть и Delphi, и C++Builder, и Visual C++. Однако прежде чем обсуждать
возможности тех или иных средств разработки, следует разобраться, что такое
автоматизация.
Коротко об автоматизации
Автоматизация — это одна из возможностей, предоставляемых технологией
Microsoft COM (Component Object Model). Не вдаваясь в подробности реализации
этой технологии, заметим, что она используется приложениями (называемыми COM-серверами)
для предоставления доступа к их объектам, а также к свойствам и методам этих
объектов другим приложениям (называемым COM-клиентами), каковыми могут быть
и средства разработки. Например, текстовый процессор, будучи COM-сервером, может
предоставлять другим приложениям доступ к документу, абзацу, закладке с помощью
соответствующих объектов. Для именования (и опознания) COM-серверов обычно используются
специальные строковые обозначения — программные идентификаторы (Programmatic
Identifier, ProgID). Они нужны для того, чтобы операционная система могла с
помощью этих идентификаторов определить, в каком именно каталоге (или на каком
компьютере локальной сети, если используется тот или иной способ удаленного
доступа к серверу) расположен исполняемый файл сервера автоматизации, и запустить
его на выполнение. О том, какие именно программные идентификаторы применяются
для того или иного приложения Microsoft Office, будет сказано в разделах, посвященных
этим приложениям.
Объекты автоматизации с точки зрения программирования мало чем отличаются от
обычных объектов, знакомых нам из теории и практики объектно-ориентированного
программирования. Как и обычные объекты, они обладают свойствами и методами.
Свойство — это характеристика объекта; например, свойством абзаца (объект
Paragraph) может быть его стиль (Style). Методом называется действие, которое
можно выполнить с объектом (например, можно сохранить документ с помощью метода
SaveAs объекта Document).
Нередко серверы автоматизации содержат наборы однотипных объектов, называемых
коллекциями. Например, текстовый процессор может содержать коллекцию документов,
а каждый документ — коллекцию абзацев.
Как узнать, какие объекты доступны в серверах автоматизации? Для этой цели
в комплект поставки любого сервера автоматизации входит документация и файлы
справки, описывающие их объектную модель. Если брать приложения Microsoft Office
2000, то это справочные файлы для программистов на Visual Basic for Applications
VBAxxx9.CHM (для Microsoft Office 97 — VBxxx8.HLP соответственно). Отметим,
что по умолчанию они не устанавливаются, так как нужны разработчикам, а не рядовым
пользователям.
Вся информация об объектах, необходимая контроллерам автоматизации, содержится
в библиотеках типов. Библиотеки типов хранятся в специальном бинарном формате
и обычно представлены в виде файлов с расширениями *.olb или *.tlb, а также
могут содержаться внутри исполняемых файлов (*.exe) или динамически загружаемых
библиотек (*.dll). Библиотеки типов можно просматривать с помощью утилиты OleView,
входящей в состав Microsoft Platform SDK, а средства разработки фирмы Borland
содержат свои собственные утилиты просмотра библиотек типов.
Заканчивая это более чем краткое введение в автоматизацию, остановимся также
на понятии связывания. Связыванием называется способ, с помощью которого переменная
или класс приложения-контроллера ссылается на объект автоматизации. Таких способов
существуют два: позднее связывание и раннее связывание.
Позднее связывание означает, что реальная ссылка на объект в переменной или
классе появляется на этапе выполнения приложения-контроллера. Этот способ обычно
более медленный, чем ранее связывание, но он доступен во всех средствах разработки,
позволяющих создавать контроллеры автоматизации, и менее чувствителен к тому,
все ли параметры методов перечислены при их вызовах в коде приложения-контроллера.
При позднем связывании корректность вызовов методов проверяется в момент их
осуществления, то есть на этапе выполнения приложения, а не на этапе его компиляции.
Раннее связывание означает, что реальная ссылка на объект автоматизации появляется
уже на этапе компиляции. Поэтому в коде приложения-контроллера требуется ссылка
на библиотеку типов (или на специальный модуль, являющийся интерфейсом к ней),
и это приводит к генерации в этом приложении классов с теми же свойствами и
методами, что и у объектов автоматизации, что делает возможными синтаксическую
проверку имен методов на этапе компиляции и доступ к именованным константам,
содержащимся в библиотеке типов. Отметим, однако, что далеко не все средства
разработки, поддерживающие позднее связывание, осуществляют также поддержку
раннего связывания.
Закончив экскурс в COM и автоматизацию, вернемся к вопросу о том, какие средства
разработки удобно применять для создания контроллеров автоматизации.
|
VBA и средства разработки контроллеров автоматизации
Как уже было сказано выше, контроллеры автоматизации можно создавать с помощью
различных средств разработки, и если вы уже используете какое-либо из инструментальных
средств, поддерживающих создание контролеров автоматизации, можно именно им
и воспользоваться. Единственное, что следует сделать — это узнать, поддерживается
ли вашим средством разработки ранее связывание, если вы планируете его использовать.
Примеры простейших контроллеров автоматизации (как правило, для Microsoft Word
или Microsoft Excel), дающие представление о том, как вызываются методы сервера,
обычно можно найти в комплекте поставки большинства современных средств разработки.
Освоение объектной модели автоматизируемого сервера можно начать с записи необходимой
последовательности действий в виде макроса с помощью VBА. Создать макрос можно,
выбрав из меню приложения Microsoft Office пункт Tools | Macro |Record New Macro.
Просмотр полученного макроса в редакторе кода VBA обычно позволяет понять, как
должен выглядеть код, реализующий эту последовательность действий.
Обсудив возможные средства разработки контроллеров автоматизации, можно наконец
перейти к самим приложениям Microsoft Office, к их объектным моделям и к их
использованию. В качестве средства разработки для приведенных ниже примеров
используется Borland Delphi 5, но поскольку в них приводится последовательность
вызова свойств и методов объектов Microsoft Office, перенос кода на другие языки
программирования не должен вызвать особых затруднений. Если специально не оговорено,
в данной статье во всех примерах используется раннее связывание.
|
Объектные модели Microsoft Office
Как было сказано выше, приложения Microsoft Office предоставляют контроллерам
автоматизации доступ к своей функциональности с помощью своей объектной модели,
представляющей собой иерархию объектов. Объекты могут предоставлять доступ к
другим объектам посредством коллекций.
В качестве иллюстрации того, как выглядит иерархия объектов Microsoft Office,
приведем небольшой фрагмент объектной модели Microsoft Word (рис.1):
В объектных моделях всех приложений Microsoft Office
всегда имеется самый главный объект, доступный приложению-контроллеру и представляющий
само автоматизируемое приложение. Для всех приложений Microsoft Office он называется
Application, и многие его свойства и методы для всех этих приложений также одинаковы.
Наиболее часто мы будем использовать следующие из них:
- Свойство Visible (доступное для объекта Application всех приложений Microsoft
Office) позволяет приложению появиться на экране и в панели задач; оно принимает
значения True (пользовательский интерфейс приложения доступен) или False (пользовательский
интерфейс приложения недоступен; это значение устанавливается по умолчанию).
Если вам нужно сделать что-то с документом Office в фоновом режиме, не информируя
об этом пользователя, можно не обращаться к этому свойству — в этом случае
приложение можно будет найти только в списке процессов с помощью приложения
Task Manager. - Метод Quit закрывает приложение Office. В зависимости от того, какое приложение
Office автоматизируется, он может иметь параметры или не иметь таковых.
|
Общие принципы создания контроллеров автоматизации
В общем случае контроллер автоматизации должен выполнять следующие действия:
- Проверить, запущена ли копия приложения-сервера.
- В зависимости от результатов проверки запустить копию автоматизируемого
приложения Office либо подключиться к уже имеющейся копии. - Сделать окно приложения-сервера видимым (в общем случае это не обязательно).
- Выполнить какие-то действия с приложением-сервером (например, создать или
открыть документы, изменить их данные, сохранить документы и пр.) - Закрыть приложение-сервер, если его копия была запущена данным контроллером,
или отключиться от него, если контроллер подключился к уже имеющейся копии.
Соответствующий код для Delphi представлен в листинге 1.
Здесь мы воспользовались функциями GetActiveOleObject и CreateOleObject для
подключения к уже запущенной копии приложения-сервера или запуска новой, если
сервер не запущен, что приводит к тому, что в вариантную переменную помещается
ссылка на объект Application соответствующего сервера.
Приведенная часть кода контроллера в других средствах разработки может выглядеть
по-другому — она не имеет прямого отношения к методам объектов Office,
так как обусловлена правилами вызова стандартных функций OLE в Delphi (за исключением
вызовов методов Visible и Quit объекта Application). А вот все то, что должно
быть вставлено вместо комментария «Здесь выполняются другие действия с объектами
приложения Office», в разных средствах разработки должно выглядеть более или
менее однотипно — используя созданную вариантную переменную, мы манипулируем
методами и свойствами объекта Application.
В заключение сделаем одно маленькое замечание касательно числа параметров методов
объектов автоматизации. В случае применения позднего связывания число указанных
в коде параметров метода не обязано совпадать с их истинным числом (которое
можно найти в описании объектной модели соответствующего приложения). В этом
случае вполне допустимым является следующий код:
App.Quit;
несмотря на то что метод Quit объекта Application в случае некоторых приложений
Microsoft Office (например, Microsoft Word) имеет параметры.
При использовании же раннего связывания, например при создании контроллеров
с помощью Delphi, следует более строго подходить к определению параметров —
их число и тип должны соответствовать описанию методов в библиотеке типов. Например,
в случае раннего связывания корректный код на Delphi для закрытия документа
Word со значениями всех параметров по умолчанию будет иметь вид:
App.Quit(EmptyParam, EmptyParam, EmptyParam);
Исключением из этого правила является Visual Basic — это средство разработки
позволяет не задумываться о числе параметров методов при написании кода.
Обсудив общие принципы создания контроллеров автоматизации и узнав, как это
делается средствами Borland Delphi, мы можем перейти к рассмотрению автоматизации
конкретных приложений Microsoft Office. Начнем с одного из самого популярных
компонентов этого пакета — с Microsoft Word.
|
Автоматизация Microsoft Word
В данном разделе мы обсудим наиболее часто встречающиеся задачи, связанные
с автоматизацией Microsoft Word. Но перед этим рассмотрим, каковы программные
идентификаторы основных объектов Microsoft Word и что представляет собой его
объектная модель.
|
Программные идентификаторы и объектная модель Microsoft Word
Для приложения-контроллера доступны непосредственно следующие объекты:
Объект |
Программный идентификатор |
Комментарий |
---|---|---|
Application |
Word.Application, Word.Application.9 |
С помощью этого программного идентификатора создается экземпляр Word |
Document |
Word.Document, Word.Document.9, Word.Template.8 |
С помощью этого программного идентификатора создается экземпляр Word |
Все остальные объекты Word являются так называемыми внутренними объектами.
Это означает, что они не могут быть созданы сами по себе; так, объект Paragraph
(абзац) не может быть создан отдельно от содержащего его документа.
Если вспомнить, что основное назначение Word — работа с документами, можно
легко понять иерархию его объектной модели (фрагмент ее был показан на рис.
1). Основным объектом в ней, как иво всех других приложениях Microsoft Office,
является объект Application, содержащий коллекцию Documents объектов типа Document.
Каждый объект типа Document содержит коллекцию Paragraphs объектов типа Paragraph,
Bookmarks типа Bookmark, Characters типа Character и т.д. Манипуляция документами,
абзацами, символами, закладками реально осуществляется путем обращения к свойствам
и методам этих объектов.
Ниже мы рассмотрим наиболее часто встречающиеся задачи, связанные с автоматизацией
Microsoft Word. Если же вам встретилась задача, не совпадающая ни с одной из
перечисленных, вы можете попытаться найти подходящий пример на Visual Basic
в справочном файле VBAWRD9.CHM, либо, как уже было сказано выше, записать необходимую
последовательность действий в виде макроса и проанализировать его код.
|
Создание и открытие документов Microsoft Word
Для создания примеров использования Microsoft Word можно использовать код создания
контроллера, приведенный выше, и модифицировать его, заменяя комментарии кодом,
манипулирующим свойствами и методами объекта Word.Application. Мы начнем с создания
и открытия документов.
Создать новый документ Word можно, используя метод Add коллекции Documents
объекта Application:
App.Documents.Add;
Как создать нестандартный документ? Очень просто — нужно указать имя шаблона
в качестве параметра метода Add:
App.Documents.Add(‘C:Program Files _ Microsoft OfficeTemplates1033Manual.dot’);
Для открытия уже существующего документа следует воспользоваться методом Open
коллекции Documents:
App.Documents.Open(‘C:MyWordFile.doc’);
Отметим, что свойство ActiveDocument объекта Word.Application указывает на
текущий активный документ среди одного или нескольких открытых. Помимо этого
к документу можно обращаться по его порядковому номеру с помощью метода Item;
например ко второму открытому документу можно обратиться так:
App.Documents.Item(2)
Отметим, что нумерация членов коллекций в Microsoft Office начинается с единицы.
Сделать документ активным можно с помощью метода Activate:
App.Documents.Item(1).Activate;
Следующее, чему следует научиться — это сохранять документ Word и закрывать
сам Word.
|
Сохранение, печать и закрытие документов Microsoft Word
Закрытие документа может быть осуществлено с помощью метода Close:
App.Documents.Item(2).Close;
или
App.ActiveDocument.Close ;
Метод Close имеет несколько необязательных (в случае позднего связывания) параметра,
влияющих на правила сохранения документа. Первый из них влияет на то, сохраняются
ли внесенные в документ изменения, и принимает три возможных значения (соответствующие
константы рекомендуется описать в приложении. См. листинг
2):
Третий параметр принимает значения True или False и влияет на то, пересылать
ли документ следующему пользователю по электронной почте. Если эта функциональность
не применяется, можно проигнорировать этот параметр.
Таким образом, при использовании этих параметров закрыть документ можно, например,
так:
App.ActiveDocument.Close(wdSaveChanges, _ wdPromptUser) ;
Просто сохранить документ, не закрывая его, можно с помощью метода Save:
App.ActiveDocument.Save;
Этот метод также имеет несколько необязательных (в случае позднего связывания)
параметров, первый из которых равен True, если документ сохраняется автоматически,
и False, если нужно выводить диалоговую панель для получения подтверждения пользователя
о сохранении изменений (если таковые были сделаны). Второй параметр влияет на
формат сохраняемого документа, и список его возможных значений совпадает со
списком значений второго параметра метода Close.
Напоминаем, что закрыть сам Word можно с помощью метода Quit объекта Word.Application.
Этот метод имеет в общем случае три параметра, совпадающих с параметрами метода
Close объекта Document.
Вывод документа на устройство печати можно осуществить с помощью метода PrintOut
объекта Document, например:
App.ActiveDocument.PrintOut;
Если нужно изменить параметры печати, следует указать значения соответствующих
параметров метода PrintOut (в случае Microsoft Word их около двадцати).
|
Вставка текста и объектовв документ и форматирование текста
Для создания абзацев в документе можно использовать коллекцию Paragraphs объекта
Document, представляющую набор абзацев данного документа. Добавить новый абзац
можно с помощью метода Add этой коллекции:
App.ActiveDocument.Paragraphs.Add;
Для вставки собственно текста в документ, тем не менее, применяется не объект
Paragraph, а объект Range, представляющий любую непрерывную часть документа
(в том числе и вновь созданный абзац). Этот объект может быть создан разными
способами. Например, можно указать начальный и конечный символы диапазона (если
таковые имеются в документе):
var Rng : Variant; ... Rng := App.ActiveDocument.Range(2,4); //со 2-го по 4-й символы
или указать номер абзаца (например, только что созданного):
Rng:= App.ActiveDocument.Paragraphs.Item(1).Range;
или указать несколько абзацев, следующих подряд:
Rng := App.ActiveDocument.Range _ (App.ActiveDocument.Paragraphs.Item(3).Range.Start,_ App.ActiveDocument.Paragraphs.Item(5).Range.End)
Вставить текст можно с помощью методов объекта Range InsertBefore (перед диапазоном)
или InsertAfter (после диапазона), например:
Rng.InsertAfter(‘Это вставляемый текст’);
Помимо объекта Range текст можно вставлять с помощью объекта Selection, являющийся
свойством объекта Word.Application и представляющий собой выделенную часть документа
(этот объект создается, если пользователь выделяет часть документа с помощью
мыши, и может быть также создан с помощью приложения-контроллера). Сам объект
Selection можно создать, применив метод Select к объекту Range, например:
var Sel : Variant; ... App.ActiveDocument.Paragraphs.Item(3).Range.Select;
В приведенном выше примере в текущем документе выделяется третий абзац.
Если мы хотим вставить строку текста в документ либо вместо выделенного фрагмента
текста, либо перед ним, это можно сделать с помощью следующего фрагмента кода:
var Sel : Variant; ... Sel := App.Selection; Sel.TypeText(‘Это текст, которым мы заменим _ выделенный фрагмент’);
Отметим, что если свойство Options.ReplaceSelection объекта Word.Application
равно True, выделенный текст будет заменен на новый текст (этот режим действует
по умолчанию); если же нужно, чтобы текст был вставлен перед выделенным фрагментом,
а не вместо него, следует установить это свойство равным False:
App.Options.ReplaceSelection := False;
Символ конца абзаца при использовании объекта Selection может быть вставлен
с помощью следующего фрагмента кода:
Sel.TypeParagraph;
К объекту Selection, так же как и к объекту Range, можно применить методы InsertBefore
и InsertAfter. В этом случае, в отличие от предыдущего, вставляемый текст станет
частью выделенного фрагмента текста.
С помощью объекта Selection, используя его свойство Font и свойства объекта
Font, такие как Bold, Italic, Size,…, можно отформатировать текст. Например,
таким образом можно вставить строку, выделенную жирным шрифтом:
Sel.Font.Bold := True; Sel.TypeText(‘Это текст, который мы выделим _ жирным шрифтом.’); Sel.Font.Bold := False; Sel.TypeParagraph;
Для наложения на вставляемый текст определенного заранее стиля можно использовать
свойство Style этого же объекта, например:
Sel.Style := ‘Heading 1’; Sel.TypeText(‘Это текст, который станет _ заголовком’); Sel.TypeParagraph;
Нередко документы Word содержат данные других приложений. Простейший способ
вставить такие данные в документ — использовать метод Paste объекта Range:
Var Rng : Variant; ... Rng := App.Selection.Range; Rng.Collapse(wdCollapseEnd); Rng.Paste;
Естественно, в этом случае в буфере обмена уже должны содержаться вставляемые
данные.
Если нужно поместить в буфер обмена часть документа Word, это можно сделать
с помощью метода Copy объекта Range:
Var Rng : Variant; ... Rng := App.Selection.Range; Rng.Copy;
Следующее, чему нужно научиться — перемещению курсора в нужное место текста,
чем мы и займемся в следующем разделе.
|
Перемещение курсора по тексту
Используя метод Collapse, можно «сжать» объект Range или объект Selection,
сократив его размер до нуля символов:
Rng.Collapse(wdCollapseEnd);
Параметр этого метода указывает, в начале или в конце исходного фрагмента окажется
новый объект Range или Selection. Если вы используете позднее связывание и ваше
средство разработки — не Visual Basic, нужно определить в приложении соответствующие
константы:
const wdCollapseStart = $00000001; //новый объект находится в начале фрагмента wdCollapseEnd = $00000000; //новый объект находится в конце фрагмента
Перемещать курсор по тексту можно с помощью метода Move объектов Range и Selection.
Этот метод имеет два параметра. Первый указывает на то, в каких единицах измеряется
перемещение — в символах (по умолчанию), словах, предложениях, абзацах и др.
Второй параметр указывает, на сколько единиц при этом нужно переместиться (это
число может быть и отрицательным; по умолчанию оно равно 1). Например, следующий
фрагмент кода:
Rng.Move;
приведет к перемещению курсора на один символ вперед, а
Rng.Move(wdParagraph,3);
приведет к перемещению курсора на три абзаца вперед. Отметим, что этот метод
использует следующие константы:
const //Единицей перемещения является: wdCharacter = $00000001; //символ wdWord = $00000002; //слово wdSentence = $00000003; //предложение wdParagraph = $00000004; //абзац wdStory = $00000006; //часть документа //напр., колонтитул, //оглавление и др.) wdSection = $00000008; //раздел wdColumn = $00000009; //колонка таблицы wdRow = $0000000A; //строка таблицы wdCell = $0000000C; //ячейка таблицы wdTable = $0000000F; //таблица
Нередко для перемещения по тексту используются закладки. Создать закладку в
текущей позиции курсора можно путем добавления члена коллекции Bookmarks объекта
Document c помощью метода Add, указав имя закладки в качестве параметра, например:
App.ActiveDocument.Bookmarks.Add(‘MyBookmark’);
Проверить существование закладки в документе можно с помощью метода Exists,
а переместиться на нее — с помощью метода Goto объектов Document, Range
или Selection:
Rng := App.ActiveDocument.Goto(wdGoToBookmark, wdGoToNext, ,‘MyBookmark’); Rng.InsertAfter(‘Текст, вставленный после закладки’);
Значения констант для этого примера таковы:
const
wdGoToBookmark = $FFFFFFFF; //перейти к закладке wdGoToNext = $00000002; //искать следующий объект в тексте
Отметим, что с помощью метода Goto можно перемещаться не только на указанную
закладку, но и на другие объекты (рисунки, грамматические ошибки и др.), и направление
перемещения тоже может быть различным. Поэтому список констант, которые могут
быть использованы в качестве параметров данного метода, довольно велик.
|
Создание таблиц
Создавать таблицы можно двумя способами. Первый заключается в вызове метода
Add коллекции Tables объекта Document и последовательном заполнении ячеек данными.
Этот способ при позднем связывании работает довольно медленно.
Второй способ, намного более «быстрый», заключается в создании текста из нескольких
строк, содержащих подстроки с разделителями (в качестве разделителя можно использовать
любой или почти любой символ, нужно только, чтобы он заведомо не встречался
в данных, которые будут помещены в будущую таблицу), и последующей конвертации
такого текста в таблицу с помощью метода ConvertToTable объекта Range. Ниже
приведен пример создания таблицы из трех строк и трех столбцов этим способом
(в качеcтве разделителя, являющегося первым параметром метода ConvertToTable,
используется запятая):
Var Rng : Variant; ... Rng := App.Selection.Range; Rng.Collapse(wdCollapseEnd); Rng.InsertAfter(‘1, 2, 3’); Rng.InsertParagraphAfter; Rng.InsertAfter(‘4,5,6’); Rng.InsertParagraphAfter; Rng.InsertAfter(‘7,8,9’); Rng.InsertParagraphAfter; Rng.ConvertToTable(‘,’);
Отметим, что внешний вид таблицы можно изменить с помощью свойства Format,
а также с помощью свойств коллекции Columns, представляющей колонки таблицы,
и коллекции Rows, представляющей строки таблицы объекта Table.
|
Обращение к свойствам документа
Свойства документа можно получить с помощью коллекции BuiltInDocumentProperties
объекта Document, например:
Memo1.Lines.Add(‘Название — ‘ + _ App.ActiveDocument.BuiltInDocumentProperties [wdPropertyTitle].Value); Memo1.Lines.Add(‘Автор — ‘ + _ App.ActiveDocument.BuiltInDocumentProperties [wdPropertyAuthor]. _ Value); Memo1.Lines.Add(‘Шаблон — ‘ + _ App.ActiveDocument.BuiltInDocumentProperties [wdPropertyTemplate]. _Value)
Константы, необходимые для обращения к свойствам документа по имени, приведены
в листинге 3.
Итак, в данном разделе мы изучили основные операции, которые наиболее часто
применяются при автоматизации Microsoft Word. Естественно, возможности автоматизации
Word далеко не исчерпываются приведенными примерами, однако я надеюсь, что,
руководствуясь основными принципами создания контроллеров Word, изложенными
в данной статье, и соответствующим справочным файлом, вы сможете ими воспользоваться —
мы с вами уже убедились, что это вовсе не так сложно.
Следующим приложением Microsoft Office, автоматизацию которого мы рассмотрим,
будет Microsoft Excel — второе по популярности приложение Microsoft Office.
|
Автоматизация Microsoft Excel
В данном разделе мы обсудим наиболее часто встречающиеся задачи, связанные
с автоматизацией Microsoft Excel. Но перед этим рассмотрим, каковы программные
идентификаторы основных объектов Microsoft Excel и что представляет собой его
объектная модель.
|
Программные идентификаторы и объектная модель Microsoft Excel
Существует три типа объектов Excel, которые могут быть созданы непосредственно
с помощью приложения-контроллера. Эти объекты и соответствующие им программные
идентификаторы перечислены ниже.
Все остальные объекты Excel являются так называемыми внутренними объектами.
Небольшой фрагмент объектной модели Microsoft Excel изображен на рис.2:
Основным в объектной модели Excel является объект Application, содержащий коллекцию
Workbooks объектов типа WorkBook. Каждый объект типа WorkBook содержит коллекцию
WorkSheets-объектов типа WorkSheet, Charts типа Chart и др. Манипуляция рабочими
книгами, их листами, ячейками, диаграммами реально осуществляется путем обращения
к свойствам и методам этих объектов.
Ниже мы рассмотрим наиболее часто встречающиеся задачи, связанные с автоматизацией
Microsoft Excel. Если вам встретилась задача, не совпадающая ни с одной из перечисленных,
вы можете попытаться найти подходящий пример на Visual Basic в справочном файле
VBAXL9.CHM, либо, как и в случае Microsoft Word, записать соответствующий макрос
и проанализировать его код.
|
Запуск Microsoft Excel, создание и открытие рабочих книг
Для создания примеров использования Microsoft Excel можно использовать код
создания контроллера, приведенный в разделе «Общие принципы создания контроллеров
автоматизации», заменив первый оператор в приведенном примере на следующий:
AppProgID := ‘Excel.Application’;
и заменить комментарии кодом, манипулирующим свойствами и методами объекта
Excel.Application. Отметим, однако, что подключение контроллера автоматизации
к имеющейся версии Excel с помощью метода GetActiveOleObject может привести
к тому, что вся клиентская часть Excel окажется невидимой (это происходит, если
имеющаяся копия Excel запущена в режиме, когда ее пользовательский интерфейс
недоступен). Причины подобного поведения автору неизвестны. Поэтому, если существует
вероятность возникновения подобной ситуации, лучше упростить код создания контроллера
и всегда создавать новую копию Excel.
Изучение создания контроллеров Excel мы начнем с создания и открытия рабочих
книг.
Создать новую рабочую книгу Excel можно, используя метод Add коллекции Workbooks
объекта Application:
App.WorkBooks.Add;
Для создания рабочей книги на основе шаблона следует указать его имя в качестве
первого параметра метода Add:
App.WorkBooks.Add(‘C:Program FilesMicrosoft _ OfficeTemplates1033invoice.xlt’);
В качестве первого параметра этого метода можно также использовать следующие
константы:
const xlWBATChart = $FFFFEFF3; //рабочая книга состоит из листа с диаграммой xlWBATWorksheet = $FFFFEFB9; //рабочая книга состоит из листа с данными
В этом случае рабочая книга будет содержать один лист типа, заданного указанной
константой (график, обычный лист с данными и др.)
Для открытия уже существующего документа следует воспользоваться методом Open
коллекции WorkBooks:
App.Documents.Open(‘C:MyExcelFile.xls’);
Отметим, что свойство ActiveWorkBook объекта Excel.Application указывает на
текущую активную рабочую книгу среди одной или нескольких открытых. Помимо этого
к рабочей книге можно обращаться по ее порядковому номеру, например ко второй
открытой рабочей книге можно обратиться так:
App.WorkBooks[2]
Обратите внимание на то, что в Delphi при использовании позднего связывания
синтаксис, используемый для обращения к членам коллекций объектов Excel, отличен
от синтаксиса, используемого для обращения к объектам Word — в случае Word
мы использовали метод Item, а в случае Excel мы обращаемся к членам коллекции
как к элементам массива. Если же вы используете Visual Basic, синтаксис, применяемый
для обращения к членам коллекций, будет одинаков для всех коллекций Microsoft
Office.
Сделать рабочую книгу активной можно с помощью метода Activate:
App.WorkBooks[2].Activate;
Следующее, чему следует научиться — это сохранять рабочие книги в файлах.
|
Сохранение, печать и закрытие рабочих книг Microsoft Excel
Закрытие документа может быть осуществлено с помощью метода Close:
App.WorkBooks[2].Close;
или
App.ActiveWorkBook.Close;
Метод Close имеет несколько необязательных (в случае позднего связывания) параметров,
влияющих на правила сохранения рабочей книги. Первый из параметров принимает
значения True или False и влияет на то, сохранять ли изменения, внесенные в
рабочую книгу. Второй параметр (типа Variant) — имя файла, в котором нужно
сохранить рабочую книгу (если в нее были внесены изменения). Третий параметр,
также принимающий значения True или False, влияет на то, следует ли пересылать
документ следующему пользователю по электронной почте, и может быть проигнорирован,
если эта функциональность не используется.
App.ActiveWorkBook.Close(True,’C:MyWorkBook.xls’);
Просто сохранить рабочую книгу, не закрывая ее, можно с помощью методов Save
или SaveAs:
App.ActiveWorkBook.Save;
или
App.ActiveWorkBook.SaveAs(‘C:MyWorkBook.xls’);
Метод SaveAs имеет более десятка параметров, влияющих на то, как именно сохраняется
документ (под каким именем, с паролем или без него, какова кодовая страница
для содержащегося в ней текста и др.).
Закрыть сам Excel можно с помощью метода Quit объекта Excel.Application. В
случае Excel этот метод параметров не имеет.
Вывод документа Excel на устройство печати можно осуществить с помощью метода
PrintOut объекта WorkBook, например:
App.ActiveWorkBook.PrintOut;
Если нужно изменить параметры печати, следует указать значения соответствующих
параметров метода PrintOut (в случае Excel их восемь).
|
Обращение к листам и ячейкам
Обращение к листам рабочей книги производится с помощью коллекции WorkSheets
объекта WorkBook. Каждый член этой коллекции представляет собой объект WorkSheet.
К члену этой коллекции можно обратиться по его порядковому номеру, например:
App.WorkBooks[1].WorkSheets[1].Name := _ ‘Страница 1’;
Приведенный выше пример иллюстрирует, как можно изменить имя листа рабочей
книги.
К листу рабочей книги можно обратиться и по имени, например:
App.WorkBooks[1].WorkSheets[‘Sheet1’].Name := _ ‘Страница 1’;
Обращение к отдельным ячейкам листа производится с помощью коллекции Cells
объекта WorkSheet. Например, добавить данные в ячейку B1 можно следующим образом:
App.WorkBooks[1].WorkSheets[‘Sheet1’].Cells[1,2].Value:=’25’;
Здесь первая из координат ячейки указывает на номер строки, вторая — на
номер столбца.
Добавление формул в ячейки производится аналогичным способом:
App.WorkBooks[1].WorkSheets[‘Sheet1’] _ .Cells[3,2].Value := ‘ =SUM(B1:B2)’;
Очистить ячейку можно с помощью метода ClearContents.
Форматирование текста в ячейках производится с помощью свойств Font и Interior
объекта Cell и их подсвойств. Например, следующий фрагмент кода выводит текст
в ячейке красным жирным шрифтом Courier кегля 16 на желтом фоне:
App.WorkBooks[1].WorkSheets[1].Cells[3,2].Interior _ .Color := clYellow; App.WorkBooks[1].WorkSheets[1].Cells[3,2].Font _ .Color := clRed; App.WorkBooks[1].WorkSheets[1].Cells[3,2] _ .Font.Name := ‘Courier’; App.WorkBooks[1].WorkSheets[1].Cells[3,2] _ .Font.Size := 16; App.WorkBooks[1].WorkSheets[1].Cells[3,2] _ .Font.Bold := True;
Объект |
Программный идентификатор |
Комментарий |
---|---|---|
Application |
Excel.Application, Excel.Application.9 |
С помощью этого программного идентификатора создается экземпляр приложения |
WorkBook |
Excel.AddIn |
С помощью этого программного идентификатора создается экземпляр расширения |
Excel.Chart, Excel.Chart.8 |
Рабочая книга, созданная с помощью этих программных идентификаторов, |
|
Excel.Sheet, Excel.Sheet.8 |
Рабочая книга, созданная с помощью этих программных идентификаторов, |
Вместо свойства Color можно использовать свойство ColorIndex, принимающее значения
от 1 до 56; таблицу соответствий значений этого свойства реальным цветам можно
найти в справочном файле VBAXL9.CHM.
Обратиться к текущей ячейке можно с помощью свойства ActiveCell объекта Excel.Application,
а узнать местоположение ячейки можно с помощью свойства Address объекта Cell,
например:
ShowMessage(App.ActiveCell.Address);
Помимо обращения к отдельным ячейкам, можно манипулировать прямоугольными областями
ячеек с помощью объекта Range, например:
App.WorkBooks[1].WorkSheets[2].Range[‘A1:C5’] _ .Value := ‘Test’; App.WorkBooks[1].WorkSheets[2].Range[‘A1:C5’] _ .Font.Color := clRed;
Приведенный выше код приводит к заполнению прямоугольного участка текстом и
к изменению цвета шрифта ячеек.
Объект Range также часто используется для копирования прямоугольных областей
через буфер обмена. Ниже приведен пример, иллюстрирующий копирование такой области:
App.WorkBooks[1].WorkSheets[2].Range[‘A1:C5’].Copy; App.WorkBooks[1].WorkSheets[2].Range[‘A11:C15’].Select; App.WorkBooks[1].WorkSheets[2].Paste;
Обратите внимание на то, что диапазон, куда копируются данные, предварительно
выделяется с помощью метода Select.
Отметим, что примерно таким же образом можно копировать данные и из других
приложений (например, из Microsoft Word).
Довольно часто при автоматизации Excel используются его возможности, связанные
с построением диаграмм. Ниже мы рассмотрим, как это сделать.
|
Создание диаграмм
Диаграммам Excel соответствует объект Chart, который может располагаться как
на отдельном листе, так и на листе с данными. Если объект Chart располагается
на листе с данными, ему соответствует член коллекции ChartObjects объекта WorkSheet
и создание диаграммы нужно начать с добавления элемента в эту колекцию:
Ch:=App.WorkBooks[1].WorkSheets[2].ChartObjects.Add(10,50,400,400);
Параметрами этого метода являются координаты левого верхнего угла и размеры
диаграммы в пунктах (1/72 дюйма).
Если же диаграмма располагается на отдельном листе (не предназначенном для
хранения данных), то создание диаграммы нужно начать с добавления элемента в
коллекцию Sheets объекта Application (которая отличается от коллекции WorkSheets
тем, что содержит листы всех типов, а не только листы с данными):
App.WorkBooks[1].Sheets.Add(,,1,xlWBATChart);
В этом случае первый параметр метода Add указывает порядковый номер листа,
перед которым нужно поместить данный лист (или данные листы, если их несколько),
второй параметр — порядковый номер листа, после которого нужно поместить данный
лист (используется обычно один из них), третий параметр — сколько нужно
создать листов, а четвертый — какого типа должен быть лист. Значения четвертого
параметра совпадают со значениями первого параметра метода Add коллекции WorkBooks
объекта Application, и при использовании имен соответствующих констант следует
определить их в приложении-контроллере.
Простейший способ создать диаграмму, с точки зрения пользователя, — создать
ее с помощью соответствующего эксперта на основе прямоугольной области с данными.
Точно так же можно создать диаграмму и с помощью контроллера автоматизации —
для этой цели у объекта Chart, являющегося свойством объекта ChartObject (члена
коллекции ChartObjects), имеется метод ChartWizard. Первым параметром этого
метода является объект Range, содержащий диапазон ячеек для построения диаграммы,
а вторым — числовой параметр, указывающий, какого типа должна быть эта
диаграмма:
Var Ch: Variant; … Ch.Chart.ChartWizard _ (App.WorkBooks[1].WorkSheets[2].Range[‘A1:C5’], _ xl3DColumn);
Возможные значения параметра, отвечающего за тип диаграммы, можно найти в справочном
файле.
У объекта Chart имеется множество свойств, отвечающих за внешний вид диаграммы,
с помощью которых можно изменить ее точно так же, как пользователи делают это
вручную. Ниже приводится пример создания заголовка диаграммы и подписей вдоль
ее осей (отметим, что оси есть не у всех типов диаграмм).
Ch.Chart.HasTitle :=1; Ch.Chart.HasLegend := False; Ch.Chart.ChartTitle.Text := _ ‘Пример диаграммы Excel ‘; Ch.Chart.Axes(1).HasTitle := True; Ch.Chart.Axes(1).AxisTitle.Text := _ ‘Подпись вдоль оси абсцисс’; Ch.Chart.Axes(2).HasTitle := True; Ch.Chart.Axes(2).AxisTitle.Text := _ ‘Подпись вдоль оси ординат’;
Еще один способ создания диаграммы — определить все ее параметры с помощью
свойств объекта Chart, включая и определение серий, на основе которых она должна
быть построена. Данные для серии обычно находится в объекте Range, содержащем
строку или столбец данных, а добавление серии к диаграмме производится путем
добавления члена к коллекции SeriesCollection, например:
App.WorkBooks[1].Sheets.Add(,,1,xlWBATChart); App.WorkBooks[1].Sheets[1].ChartType := xl3DPie; Rng:=App.WorkBooks[1].WorkSheets[2].Range[‘B1:B5’]; App.WorkBooks[1].Sheets[1].SeriesCollection.Add(Rng);
В данном примере к диаграмме, созданной на отдельном листе, специально предназначенном
для диаграмм, добавляется одна серия на основе диапазона ячеек другого листа.
Мы изучили основные операции, применяемые при автоматизации Microsoft Excel.
Описания некоторых аналогичных операций для Microsoft Word, например обращение
к свойствам документов, были здесь опущены во избежание повторов. Возможности
автоматизации Microsoft Excel и Word далеко не исчерпываются приведенными примерами.
Сведения о них можно всегда найти в соответствующем справочном файле.
В следующих статьях данного цикла будет рассмотрена автоматизация других приложений
Microsoft Office — Microsoft PowerPoint, Microsoft Access, Microsoft Outlook
и др.
КомпьютерПресс 11’2000
Создание форм и шаблонов
Основные понятия
Шаблон — это файл, содержащий настройки
Word. Любой документ Word создается на основе некоторого шаблона.
Большинство создается на основе шаблона Normal.dot, который загружается
автоматически, например, при нажатии кнопки «Создать» на стандартной
панели инструментов. При открытии документа, основанного на некотором
шаблоне, последний загружается автоматически.
Форма — это защищенный документ, содержащий
поля для ввода информации и применяемый для заполнения бланков, таблиц и
других типовых документов.
Шаблоны и формы служат для автоматизации разработки типовых
документов и для организации работы с ними неквалифицированных
пользователей ЭВМ.
В редакторе Word имеется набор шаблонов для часто используемых документов. Как правило, эти шаблоны хранятся в папке MSOfficeШаблоны. Однако, пользователь может создавать и свои собственные шаблоны.
В шаблоне может храниться следующая информация:
- стили;
- параметры страницы и бумаги;
- обычный текст, таблицы, рисунки;
- формы;
- макросы;
- пользовательские меню;
- панели инструментов и другая информация.
Стиль — это набор форматирующих команд,
сохраняемых под своим именем для многократного использования. Стиль
определяет внешний вид документа. Шаблон Normal.dot содержит несколько
стилей, в том числе стиль «Обычный», используемый при создании
большинства документов.
Создание форм
Формой может быть любой документ, содержащий поля. Существует три типа полей:
для ввода текста; флажок;
раскрывающийся список. Порядок вставки полей достаточно прост: установите курсор в позицию для ввода поля формы, обратитесь к меню Вид/Панели инструментов/Формы. На панели «Формы»
выберите один из трех типов полей. Поскольку формы очень часто
создаются для быстрой разработки типовых документов, на панели «Формы»
имеются инструменты для вставки и редактирования таблиц и для защиты
формы.
Построение формы проходит в 3 этапа:
- создание текстовой основы (структуры) формы;
- вставка и настройка полей формы;
- защита и сохранение формы.
Первый этап является обычным оформлением документа. Для форматирования сложных документов часто используются таблицы.
О вставке полей формы говорилось выше, поэтому остановимся на их настройке.
Для настройки поля следует на панели «Формы» выбрать «Параметры поля формы». В зависимости о того какое поле выделено, откроется одно из трех окон для настройки.
Окно «Параметры текстового поля» содержит следующие основные поля:
- «Тип» — позволяет выбрать тип поля формы. Если, например, выбрать
числовой тип, то при вводе текста в него будет выдано сообщение об
ошибке; - «Текст по умолчанию» — задает текст, который будет появляться в поле перед его заполнением;
- «Максимальная длина» — максимальное количество символов, которое разрешается вводить в поле;
- «Формат текста» — позволяет выбрать различные форматы текста для более жесткого контроля за вводом.
Окно «Параметры флажка» позволяет настроить размер флажка и его состояние по умолчанию: «Снят» или «Установлен». Флажок может быть связан с макросом, текстом справки и т.д.
Окно «Параметры поля со списком» позволяет
задать раскрывающийся список, содержащий до 25 значений, из которых
пользователь может выбирать нужное значение при заполнении поля формы.
Имеется возможность добавления, удаления и изменения порядка следования
значений.
Во всех окнах для настройки параметров полей имеется кнопка «Текст
справки», с помощью которой можно подготовить справку по каждому из
полей (в печатных документах этой цели служат подстрочные надписи). В
окне «Текст справки для поля формы» имеются две вкладки: «Строка
состояния» и «Клавиша F1». Текст справки, введенный на первой вкладке
будет автоматически выводиться в строке состояния при активизации
соответствующего поля. Справка, введенная на второй вкладке, выводится в
отдельном окне при нажатии клавиши F1.
Созданный документ можно назвать формой, если он имеет поля формы и
защищен. В незащищенном документе поля не будут проявлять необходимых
свойств. Кроме того, защищенная форма отличается тем, что ее нельзя
редактировать, а можно только заполнять поля формы. Защитить форму можно
двумя способами.
Первый способ:
- выбрать меню Сервис/Установить защиту… ;
- в окне «Защита документа» установить метку «Запретить любые изменения, кроме ввода данных в поля форм» и нажать
«Ok»; - при необходимости ввести текст пароля для открытия документа.
Второй способ заключается в выборе инструмента «Защита формы» на панели «Формы».
Для редактирования структуры формы защиту следует снять повторным нажатием на инструмент «Защита формы».
Создание шаблона
-
Выполните Файл/Создать…. В окне «Создание документа» установите метку «Шаблон», найдите и выделите шаблон «Обычный», на основе которого будет создан свой шаблон. Нажмите «Ok».
-
Установите требуемые параметры форматирования документа, введите
тексты и другую информацию, которую следует сохранить в шаблоне. -
Выберите меню Файл/Сохранить как… и папку, в которой нужно сохранить шаблон. В поле «Имя файла» введите имя шаблона и нажмите «Ok». Расширение .dot будет добавлено к имени шаблона автоматически.
Загрузка шаблона
Существует два способа загрузки шаблона:
- при открытии документа, основанного на некотором шаблоне, последний загружается автоматически;
- при создании нового документа выберите меню Файл/Создать…
. В окне «Создание документа» установите
переключатель «Документ», найдите и выделите нужный шаблон и нажмите
Ok.

Контрольные вопросы
- Что такое шаблон?
- На основе какого шаблона создается большинство документов?
- Что называется формой?
- Для чего служат шаблоны и формы?
- Какая информация может храниться в шаблоне?
- Что называется стилем?
- Какие документы могут служить в качестве формы?
- Какие типы полей может содержать документ?
- Как вставить поле?
- Через сколько этапов проходит построение формы?
- Как выполняется создание текстовой основы формы?
- Каковы возможности настройки формы?
- Как защитить форму?
- Как создается шаблон?
- Как загрузить шаблон?
В MS Word можно выполнять различные задачи, и далеко не всегда работа в этой программе ограничивается банальным набором или редактированием текста. Так, выполняя в Ворде научно-техническую работу, набирая реферат, диплом или курсовую, делая и оформляя доклад, сложно обойтись без того, что принято называть расчетно-пояснительной запиской (РПЗ). Сама же РПЗ обязательно должна включать оглавления (содержание).
Зачастую, студенты, как и работники тех или иных организаций, сначала оформляют основной текст расчетно-пояснительной записки, добавляя в него основные разделы, подразделы, графическое сопровождение и многое другое. Закончив эту работу, они переходят непосредственно к оформлению содержания созданного проекта. Пользователи, не знающие всех возможностей Microsoft Word, для таких целей начинают выписывать в столбик поочередно названия каждого из разделов, указывают соответствующие им страницы, перепроверяют то, что получилось в результате, нередко что-то корректируя по ходу, и только потом отдают готовый документ преподавателю или начальнику.
Такой подход к оформлению содержания в Ворде хорошо работает лишь с документами небольшого объема, коими могут быть лабораторные или типовые расчеты. Если же документ — это курсовая или дипломная работа, научная диссертация и тому подобное, то соответствующий ему РПЗ будет состоять из нескольких десятков основных разделов и еще большего количества подразделов. Следовательно, оформление содержания столь объемного файла вручную займет довольно много времени, параллельно затратив нервы и силы. Благо, сделать содержание в Word можно и автоматически.
Создание автоматического содержания (оглавления) в Ворде
Самое верное решение — начинать создание любого обширного, большого по объему документа именно с создания содержания. Даже в случае, если у вас еще не написано ни одной строчки текста, потратив всего 5 минут на предварительную настройку MS Word, вы сэкономите себе значительно больше времени и нервов в дальнейшем, направив все усилия и старания исключительно на работу.
1. Открыв Ворд, перейдите на вкладку «Ссылки», расположенную на панели инструментов вверху.
2. Кликните на пункт «Оглавление» (первый слева) и создайте «Автособираемое оглавление».
3. Перед вами появится сообщение о том, что элементы оглавления отсутствуют, что, собственно, не удивительно, ведь вы открыли пустой файл.
Примечание: Дальнейшую «разметку» содержания вы можете делать по ходу набора текста (что более удобно) или по завершению работы (займет заметно больше времени).
Первый автоматический пункт содержания (пустой), который перед вами появился — это и есть ключевое оглавление, под шапкой которого и будут собираться все остальные пункты работы. Желая добавить новый заголовок или подзаголовок, просто установите курсор мышки на нужном месте и кликните по пункту «Добавить текст», расположенному на верхней панели.
Примечание: Вполне логично, что вы можете создавать не только заголовки меньшего уровня, но и основные. Кликните по месту, где вы хотите его разместить, разверните пункт «Добавить текст» на панели управления и выберите «Уровень 1»
Выберете желаемый уровень заголовка: чем больше цифра, тем «глубже» будет этот заголовок.
Чтобы просмотреть содержание документа, а также для быстрой навигации по его содержанию (созданному вами), необходимо перейти во вкладку «Вид» и выбрать режим отображение «Структура».
Весь ваш документ разбит на пункты (заголовки, подзаголовки, текст), каждый из которых имеет свой уровень, предварительно указываемый вами. Отсюда между этими пунктами можно быстро и удобно переключаться.
В начале каждого заголовка есть небольшой синий треугольничек, кликнув по которому, вы можете скрыть (свернуть) весь текст, который относится к этому заголовку.
По ходу написания вами текста созданное в самом начале «Автособираемое оглавление» будет изменяться. В нем будут отображаться не только создаваемые вами заголовки и подзаголовки, но и номера страниц, на которых они начинаются, уровень заголовка тоже будет отображаться визуально.
Это и есть столь необходимое для каждой объемной работы автосодержание, сделать которое в Ворде очень просто. Именно содержание будет находиться в начале вашего документа, как это и требуется для РПЗ.
Автоматически сформированное оглавление (содержание) всегда хорошо выровнено и корректно отформатировано. Собственно, внешний вид заголовков, подзаголовков, как и всего текста всегда можно изменить. Делается это точно так же, как с размером и шрифтом любого другого текста в MS Word.
По ходу выполнения работы автоматическое содержание будет дополняться и расширяться, в нем будут проставляться новые заголовки и номера страниц, а из раздела «Структура» вы всегда сможете получить доступ к необходимой части своей работы, обратиться к нужной главе, вместо того, чтобы пролистывать документ вручную. Стоит отметить, что особенно удобной работа с документом с автосодержанием становится после его экспорта в PDF-файл.
Урок: Как конвертировать PDF в Word
На этом все, теперь вы знаете, как создать автоматическое содержание в Ворде. Стоит отметить, что данная инструкция применима ко всем версиям продукта от Майкрософт, то есть, таким образом можно сделать автоматическое оглавление в ворде 2003, 2007, 2010, 2013, 2016 и любых других версиях этого компонента офисного пакета. Теперь вы знаете немного больше и сможете работать более продуктивно.
Министерство образования Республики Беларусь
Учреждение образования
«МОГИЛЕВСКИЙ ГОСУДАРСТВЕННЫЙ УНИВЕРСИТЕТ ПРОДОВОЛЬСТВИЯ»
Кафедра «Информатика и вычислительная техника»
АВТОМАТИЗАЦИЯ РАБОТЫ В MS WORD 2003
Методические указания для студентов всех специальностей
дневной и заочной формы обучения
Могилев 2008
2
УДК 681.3
Рассмотрен и рекомендован к изданию на заседании кафедры ИВТ Протокол № 11 от « 1 » 07 2008 г.
Составитель И. П. Овсянникова
Рецензент кандидат технических наук Ж.В. Кошак
©УО «Могилевский государственный университет продовольствия», 2008
3
СОДЕРЖАНИЕ |
||
Введение ……………………………………………………………………………………………………. |
4 |
|
1 АВТОМАТИЗАЦИЯ ПОДГОТОВКИ БОЛЬШИХ ДОКУМЕНТОВ…………….. |
4 |
|
1.1 |
Создание колонтитулов …………………………………………………………………………. |
4 |
1.2 |
Создание сноски……………………………………………………………………………………. |
5 |
1.3 |
Применение стиля …………………………………………………………………………………. |
6 |
1.4 |
Создание оглавления……………………………………………………………………………… |
7 |
1.5 |
Верстка страниц. Создание многоколонного документа…………………………… |
7 |
1.6 |
Порядок выполнения работы………………………………………………………………….. |
9 |
1.7 |
Контрольные вопросы……………………………………………………………………………. |
9 |
2 СОЗДАНИЕ ШАБЛОНОВ ДОКУМЕНТОВ С ИСПОЛЬЗОВАНИЕМ ПОЛЕЙ
ФОРМЫ…………………………………………………………………………………………………… |
10 |
|
2.1 |
Понятие шаблонов документов…………………………………………………………….. |
10 |
2.2 |
Создание шаблонов документов …………………………………………………………… |
10 |
2.2.1 Текстовое поле» формы. Параметры текстовых полей…………………………. |
11 |
|
2.2.2 Поле формы «Список» ………………………………………………………………………. |
13 |
|
2.2.3 Поле формы «Флажок» ……………………………………………………………………… |
14 |
|
2.3 |
Редактирование шаблона……………………………………………………………………… |
14 |
2.4 |
Защита шаблона от изменений……………………………………………………………… |
15 |
2.5 |
Порядок выполнения работы………………………………………………………………… |
15 |
2.6 |
Контрольные вопросы…………………………………………………………………………. |
16 |
3 ПОДГОТОВКА ДОКУМЕНТОВ ПУТЕМ СЛИЯНИЯ………………………………. |
17 |
|
3.1 |
Общая характеристика слияния…………………………………………………………….. |
17 |
3.2 |
Этапы подготовки составного документа………………………………………………. |
18 |
3.3 |
Слияние документов ……………………………………………………………………………. |
19 |
3.4 |
Отбор данных из источника данных ……………………………………………………… |
21 |
3.5 |
Порядок выполнения работы………………………………………………………………… |
22 |
3.6 |
Контрольные вопросы………………………………………………………………………….. |
23 |
Список рекомендуемой литературы: ………………………………………………………….. |
23 |
|
Приложение А………………………………………………………………………………………….. |
24 |
|
Приложение В ………………………………………………………………………………………….. |
25 |
4
ВВЕДЕНИЕ
В данных методических указаниях рассматриваются вопросы повышения эффективности работы в MS Word 2003 за счет автоматизации подготовки больших документов, создания шаблонов документов с использованием полей форм, подготовки документов путем слияния.
Данные методические указания состоят из 3 лабораторных работ и 2 приложений, содержащих задания к лабораторным работам.
1 АВТОМАТИЗАЦИЯ ПОДГОТОВКИ БОЛЬШИХ ДОКУМЕНТОВ
Лабораторная работа
Цель работы
Освоить приемы форматирования больших документов в MS Word 2003.
1.1 Создание колонтитулов
Колонтитул – текст или рисунок, который печатается внизу или вверху каждой страницы документа. В колонтитуле обычно размещают номера страниц, название книги или текущей главы. В зависимости от расположения (в верхнем или в нижнем поле страницы) колонтитулы бывают верхними или нижними.
Для создания колонтитулов используют команду Вид / Колонтитулы. После этого на экране появляется панель Колонтитулы (рисунок 1).
Для перехода из поля верхнего колонтитула в поле нижнего колонтитула и обратно используется кнопка .
Рисунок 1 – Диалоговое окно Колонтитулы
Введенный текст колонтитула располагается в пунктирной рамке, указывающей границы колонтитула. Текст колонтитула форматируется как обычный текст. Для вставки полного имени файла необходимо использовать
кнопку . Для вставки номера и количества страниц используют кнопки
. Для вставки даты и времени – кнопки
. Для изменения
формата номера страницы служит кнопка |
. В режиме отображения |
5
колонтитулов основный текст документа редактировать невозможно. Если оставить поле колонтитула пустым, то колонтитул будет отсутствовать. Для
удаления колонтитула следует его выделить и нажать клавишу Delete.
1.2 Создание сноски
Иногда для пояснения некоторых редко используемых слов или описанных ранее понятий используют сноски (разъяснения), которые чаще всего расположены либо в конце страницы, либо в конце главы или книги. Подобные сноски можно создать средствами Word. Для этого нужно
воспользоваться командой Вставка / Ссылка/ Сноска. В открывшемся диалоговом окне (рисунок 2) необходимо выбрать вид сноски в зависимости от ее месторасположения и нумерацию или маркировку.
Рисунок 2 – Диалоговое окно Сноски
Для создания сноски необходимо:
∙·поместить курсор в то место, где требуется сделать сноску;
∙·выполнить команду Вставка / Ссылка/ Сноска, в появившемся диалоговом окне выбрать вид создаваемой сноски: обычная или концевая (внизу страницы или в конце документа);
∙·выбрать опцию Нумерация / Автоматическая (по умолчанию) или ввести в поле Другая подходящий символ (знак) сноски, задав все параметры сноски ввести нужный текст сноски в появившееся окно.
6
1.3 Применение стиля
Стиль оформления — это поименованный набор настроек параметров форматирования, которые можно применить к выделенному тексту. Каждый стиль состоит из таких атрибутов, как тип, тип и размер шрифта; интервалы, способ выравнивания текста, отступы и табуляция. Стили позволяют быстро отформатировать документ. При использовании стилей обеспечивается простота форматирования абзацев и заголовков текста, единство оформления документа. Особенно необходимы стили при работе с объемными документами. Можно один раз задать форматы стилей и назначать их для заголовков, списков, табуляции и других элементов текста, а не форматировать каждый из них в отдельности.
Работа со стилями состоит в создании, настройке и использовании стилей. Для выбора стиля из списка необходимо выделить текст, который надо отформатировать, щелкнуть на стрелку списка Стиль на панели инструментов
Форматирование, затем выбрать нужный или воспользоваться командой
Формат / Стили и форматирование.
Для того, чтобы привести текст к единому стилю, необходимо выделить заголовки 1 – го уровня, затем выполнить команду Формат / Стили и форматирование и выбрать из открывшегося окна «Стили» (рисунок 3 ) Заголовок 1, далее командой Формат / Абзац задать необходимое выравнивание, командой Формат / Шрифт задать нужный размер шрифта и начертание.
Рисунок 3 – Диалоговое окно Стиль
Аналогичным способом можно задать стиль заголовкам 2 – го уровня (стиль Заголовок 2), выбрав необходимое выравнивание, межстрочный интервал, начертание, размер шрифта и т. д. Тексту абзацев также можно задать свой стиль. Для того, чтобы поменять в стиле какую–нибудь установку (например, размер шрифта или начертание) необходимо воспользоваться
командой Формат / Стиль / Изменить / Формат / Абзац (Шрифт и т. д.).
Кнопка Формат по образцу позволяет копировать стили из выделенного текста и применять их к другому фрагменту текста. Название
7
сохраненного стиля появится в списке Стиль на панели инструментов Форматирование. Приложение Word содержит большое количество готовых стилей, но можно также создать и свои собственные.
1.4Создание оглавления
ВWord можно автоматически создать оглавление или содержание документа. Сделать это возможно после того, как текст приведен к единому стилю заголовков 1-го, 2-го и т. д. уровней. Для того, чтобы создать оглавление,
необходимо воспользоваться командой Вставка/ Ссылка/ Оглавление и указатели… (рисунок 4), на вкладке Оглавление выбрать вид оглавления, установить нужные флажки, установить уровень вложенности заголовков для оглавления и выбрать вид заполнения (свободное место между названием главы
иномером страницы).
Рисунок 4 –Диалоговое окно Оглавление и указатели…
1.5 Верстка страниц. Создание многоколонного документа
Верстка страниц определяет организацию страницы, задавая соотношения между границами, колонками и расстоянием между колонками. Одноколоночная верстка обычно используется для книг, и писем, в то время как двух — и трехколоночный формат больше подходит для журналов и газет.
Microsoft Word позволяет верстать текст в несколько колонок. Текст вводится в
них последовательно, переходя к следующей колонке после заполнения предыдущей. Для многоколонной верстки следует перейти в режим Разметка
8
страниц (команда Вид / Разметка страниц), так как в режиме Обычный текст не будет отображен в несколько колонок.
Существуют два варианта использования многоколоночная верстки.
∙Весь документ разбит на одинаковое количество колонок одинаковой ширины.
∙Различные части документа разбиты на различное число колонок или ситуация, когда колонки имеют различную ширину. В этом случае
необходимо разбить документ на разделы, каждый из которых будет иметь свое разделение на колонки.
Для создания колонок текст сначала выделяют, а затем используют команду
Формат / Колонки. После этого открывается диалоговое окно Колонки (рисунок 5), где в поле Число колонок необходимо ввести нужное число колонок или выбрать один из рисунков в рамке Тип. Флажок Разделитель устанавливает линию между столбцами текста. Если включен флажок колонки одинаковой ширины, то все колонки будут иметь одинаковую ширину. Если выключить этот флажок, то можно ввести для каждой колонки точные значения
ее ширины и расстояния между колонками в поля Ширина и промежуток.
Рисунок 5 – Диалоговое окно Колонки
В поле Применить указывается часть документа, для которой будут действовать выбранные режимы: К текущему разделу, До конца документа, Ко всему документу.
Создать колонки одинаковой ширины можно с помощью кнопки на панели инструментов Стандартная . После щелчка на ней появляется окно, в котором следует выделить нужное количество колонок и нажать кнопку мыши.
Изменять ширину колонок и расстояние между ними можно с помощью горизонтальной координатной линейки.
9
Удаление колонок – это операция установления одной колонки для всего документа.
1.6Порядок выполнения работы
∙Ввести текст по образцу из Приложения А.
∙После каждого абзаца вставить разрыв страницы.
∙Вставить вверху текста номера страниц.
∙Создать верхний колонтитул, вставить в него полное имя файла, количество страниц в документе. Изменить формат номера страницы. Создать нижний колонтитул, вставить в него дату и время.
∙Создать обычную сноску из 1 предложения 5-го абзаца. Выбрать
автоматическую нумерацию сноски.
∙Привести текст к единому стилю. Для заголовков с нумерацией 1, 2, 3 и т.д. задать стиль Заголовок 1 с выравниванием по центру, размером шрифта 18, начертанием «полужирный». Для заголовков с нумерацией 1.1, 1.2, … и т.д. задать стиль Заголовок 2 с выравниванием по правому краю, одинарным межстрочным интервалом, начертанием «полужирный», размер шрифта 16. Тексту абзацев задать стиль Основной текст с выравниванием по ширине, размер шрифта 14, начертание «обычный», полуторный межстрочный интервал. Поменять в стиле Основной текст размер шрифта с 14 на 12, затем, ереформатировать текст абзацев.
∙Создать оглавление вида Современный.
∙Разбить текст на две колонки. Выбрать для 1- ой колонки ширина = 3 см, промежуток = 1,25 см; для 2 – ой колонки ширина = 4 см.
∙Сохранить документ в файле под другим именем и оформить отчет.
1.7Контрольные вопросы
1Как создать колонтитул?
2Для чего используются колонтитулы?
3Что такое компьютерная верстка?
4Как разбить текст на колонки?
5Как вставить разрыв страницы?
6Что такое стиль?
7Как вставить сноску?
8Для чего применяют стили оформления?
9Как создать автоматическое оглавление?
10
2 СОЗДАНИЕ ШАБЛОНОВ ДОКУМЕНТОВ С ИСПОЛЬЗОВАНИЕМ ПОЛЕЙ ФОРМЫ
Лабораторная работа
Цель работы
Целью данной работы является изучение принципов работы с шаблонами в текстовом редакторе Word.
2.1 Понятие шаблонов документов
Шаблон документа – это средство для создания однотипных документов. Параметры, хранимые в шаблонах, определяют свойства нового документа, созданного на основе данного шаблона. Использование шаблонов документов автоматизирует создание и форматирование текстов, имеющих сходную структуру. Шаблон является основой для других документов, а сам остаётся неизменным.
2.2 Создание шаблонов документов
Для разработки шаблонов документов применяется команда Файл/ Создать с указанием типа документа – Шаблон. При этом создается новый документ со стандартным именем Шаблон1, для которого можно выполнить все необходимые оформления, разметки, подготовить стили, макрокоманды и т.д., а затем сохранить документ со стандартным расширением .dot в каталоге, содержащем шаблоны.
При создании шаблона задаётся неизменяемый (постоянный) текст в виде обычной символьной строки и модифицируемая (переменная) часть документа
ввиде полей.
Кпостоянной части шаблона относится неизменяемый при вводе текст, таблицы фиксированного содержания, оформительские элементы: рисунки, графики, линии разметки, элементы оформления — заполнение, обрамление.
Переменная часть документа включает текст, списки, флажки и используется для ввода информации при заполнении шаблона.
Для размещения в документе переменных данных служат поля, настройка которых выполняется путём вызова Опций поля.
Поля бывают двух основных типов:
1) Собственно поле. Это объект Microsoft Word, представляющий собой вычисляемую и изменяемую величину (например, дата, время, количество страниц и т.д.) или команду по управлению документом (переформатировать, обновить оглавление и т.п.). Такое поле можно использовать и в шаблоне, и в обычном документе, создаваемом не на основе шаблона. Для добавления поля к шаблону используют команду Вставка/Поле. В появившемся окне выбирают нужную категорию поля и само поле (например, для вставки поля типа Date необходимо указать категорию поля Дата и время, затем выбрать само поле Date). При этом внизу появляется его описание, а вид поля можно задать с помощью кнопки Параметры. Наиболее часто встречаются поля Page, которое
Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]
- #
- #
- #
- #
- #
- #
- #
- #
- #
- #
- #