Resumen

Con automatización, puede hacer mediante programación casi cualquier cosa que el usuario pueda hacer manualmente en Microsoft Office Word. Sin embargo, si tiene una gran cantidad de texto que desea introducir y dar formato, es posible que necesite una gran cantidad de código. Si puede representar los datos como una cadena rtf (formato de texto enriquecido), puede reducir con frecuencia el código de automatización. Puede crear una cadena RTF, copiar la cadena RTF en el Portapapeles y, después, pegar la cadena RTF en el documento.En este artículo se describe cómo crear un ejemplo sencillo de Visual Basic que inicia Word, crea un documento nuevo y agrega texto con formato al documento mediante una cadena RTF predefinida.

Más información

Para crear el proyecto de ejemplo, siga estos pasos:

  1. Inicie Visual Basic y, a continuación, cree un nuevo EXE estándar. De forma predeterminada, se crea un formulario denominado Formulario1.

  2. Agregue un CommandButton al formulario, haga doble clic en el botón Comando y, a continuación, agregue el código siguiente al evento 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. Agregue el código siguiente a la sección Declaraciones generales del módulo Formulario.

    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. Presione la tecla F5 para ejecutar el proyecto. Word se inicia y, a continuación, se crea un nuevo documento que contiene texto con formato.

Referencias

Para obtener más información y ejemplos para desarrollar Office soluciones, visite los siguientes sitios web de Microsoft:

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

¿Necesita más ayuda?

¿Quiere más opciones?

Explore las ventajas de las suscripciones, examine los cursos de aprendizaje, aprenda a proteger su dispositivo y mucho más.