Загальні відомості

Автоматизація передбачає виконання програмних засобів майже будь-які дії, які користувач може виконати Microsoft Office Word. Однак якщо потрібно ввести та відформатувати багато тексту, може знадобити багато коду. Якщо дані можна представити як рядок форматованого тексту (RTF), можна часто зменшувати код автоматизації. Ви можете створити рядок RTF, скопіювати рядок RTF до буфера обміну, а потім вставити рядок RTF у документ.У цій статті описано, як створити простий Visual Basic, який запускає програму Word, створює новий документ і додає до документа певний відформатований текст за допомогою попередньо створеного рядка RTF.

Додаткові відомості

Щоб створити зразок проекту, виконайте такі дії:

  1. Запустіть Visual Basic а потім створіть стандартний EXE. За замовчуванням створюється форма з іменем Form1.

  2. Додавання кнопки CommandButton до форми, двічі клацніть елемент CommandButton і додайте наведений нижче код до події Click.

    'sRTF represents the rich-text-formatted string to paste into WordDim sRTF As StringsRTF = "{\rtf1\ansi\ansicpg1252\deff0\deftab720{\fonttbl" & _       "{\f0\fswiss MS Sans Serif;}{\f1\froman\fcharset2 Symbol;}" & _       "{\f2\froman\fprq2 Times New Roman;}}" & _       "{\colortbl\red0\green0\blue0;\red255\green0\blue0;}" & _       "\deflang1033\horzdoc{\*\fchars }{\*\lchars }" & _       "\pard\plain\f2\fs24 Line 1 of \plain\f2\fs24\cf1" & _       "inserted\plain\f2\fs24  file.\par }"'Copy the contents of the Rich Text to the clipboardDim lSuccess As LongDim lRTF As LongDim hGlobal As LongDim lpString As LonglSuccess = OpenClipboard(Me.hwnd)lRTF = RegisterClipboardFormat("Rich Text Format")lSuccess = EmptyClipboardhGlobal = GlobalAlloc(GMEM_MOVEABLE Or GMEM_DDESHARE, Len(sRTF))lpString = GlobalLock(hGlobal)CopyMemory lpString, ByVal sRTF, Len(sRTF)GlobalUnlock hGlobalSetClipboardData lRTF, hGlobalCloseClipboardGlobalFree hGlobal'Paste into a new Word documentDim oWord As ObjectDim oDoc As ObjectSet oWord = CreateObject("word.application")Set oDoc = oWord.Documents.AddoWord.Selection.PasteoWord.Visible = True
  3. Додайте наведений нижче код до розділу Загальні оголошення модуля форми.

    Private Declare Function OpenClipboard Lib "user32" (ByVal hwnd As Long) As LongPrivate Declare Function RegisterClipboardFormat Lib "user32" Alias _    "RegisterClipboardFormatA" (ByVal lpString As String) As LongPrivate Declare Function EmptyClipboard Lib "user32" () As LongPrivate Declare Function CloseClipboard Lib "user32" () As LongPrivate Declare Function SetClipboardData Lib "user32" ( _    ByVal wFormat As Long, ByVal hMem As Long) As LongPrivate Declare Function GlobalAlloc Lib "kernel32" (ByVal wFlags As Long, _    ByVal dwBytes As Long) As LongPrivate Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" ( _    ByVal Destination As Long, Source As Any, ByVal Length As Long)Private Declare Function GlobalUnlock Lib "kernel32" (ByVal hMem As Long) As LongPrivate Declare Function GlobalLock Lib "kernel32" (ByVal hMem As Long) As LongPrivate Declare Function GlobalFree Lib "kernel32" Alias "GlobalFree" ( _     ByVal hMem As Long) As LongPrivate Const GMEM_DDESHARE = &H2000Private Const GMEM_MOVEABLE = &H2
  4. Натисніть клавішу F5, щоб запустити проект. Запуститься програма Word, а потім створиться новий документ із форматованим текстом.

Посилання

Докладні відомості та зразки для розробки рішень Office див. на таких веб-сайтах Microsoft:

http://support.microsoft.com/ofd http://msdn.microsoft.com/office

Потрібна додаткова довідка?

Потрібні додаткові параметри?

Ознайомтеся з перевагами передплати, перегляньте навчальні курси, дізнайтесь, як захистити свій пристрій тощо.