Estás trabajando sin conexión, espera a que vuelva la conexión a Internet

Cómo utilizar Automatización para obtener y configurar propiedades de documentos de Office mediante Visual C# .NET

Ha finalizado el soporte técnico para Office 2003

Microsoft puso fin al soporte técnico para Office 2003 el 8 de abril de 2014. Este cambio ha afectado a las actualizaciones de software y las opciones de seguridad. Sepa qué significa esto en su caso y cómo puede mantenerse protegido.

Este artículo se publicó anteriormente con el número E303296
Resumen
En este artículo se demuestra cómo crear un cliente de Automatización de Microsoft Visual C# .NET que trate las propiedades de un documento de Microsoft Word. Aunque el ejemplo de código de este artículo es específico de Word, se pueden aplicar las mismas técnicas al automatizar Microsoft Excel y Microsoft PowerPoint.
Más información

Crear un cliente de Automatización para Microsoft Word

  1. Inicie Microsoft Visual Studio .NET.
  2. En el menú Archivo, haga clic en Nuevo y, después, en Proyecto. Seleccione Aplicación para Windows en los tipos de proyectos de Visual C#. De forma predeterminada, se crea Form1.
  3. Agregue una referencia a Microsoft Word Object Library. Para ello, siga estos pasos:
    1. En el menú Proyecto, haga clic en Agregar referencia.
    2. En la ficha COM, busque Microsoft Word Object Library y, a continuación, haga clic en Seleccionar.

      Nota: Microsoft Office 2003 incluye ensamblados de interoperabilidad primarios (PIA, Primary Interop Assemblies). Microsoft Office XP no incluye PIA, pero se pueden descargar. Para obtener información adicional acerca de los PIA de Office XP, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
      328912 INFO: Los PIA de Microsoft Office XP ya se pueden descargar
    3. Haga clic en Aceptar en el cuadro de diálogo Agregar referencias para aceptar sus selecciones. Si se le pregunta si desea generar contenedores para las bibliotecas seleccionadas, haga clic en .
  4. En el menú Ver, haga clic en Cuadro de herramientas para mostrar el cuadro de herramientas y, a continuación, agregue un botón a Form1.
  5. Haga doble clic en Button1. Aparece la ventana de código del formulario.
  6. En la ventana de código, reemplace el código siguiente
    private void button1_Click(object sender, System.EventArgs e){}					
    por:
    private void button1_Click(object sender, System.EventArgs e){   Word.Application oWord;   Word._Document oDoc;   object oMissing = Missing.Value;   object oDocBuiltInProps;   object oDocCustomProps;			   //Create an instance of Microsoft Word and make it visible.   oWord = new Word.Application();   oWord.Visible = true;   //Create a new Document and get the BuiltInDocumentProperties collection.   oDoc = oWord.Documents.Add(ref oMissing, ref oMissing, ref oMissing,                               ref oMissing);   oDocBuiltInProps = oDoc.BuiltInDocumentProperties;   Type typeDocBuiltInProps = oDocBuiltInProps.GetType();   //Get the Author property and display it.   string strIndex = "Author";   string strValue;   object oDocAuthorProp = typeDocBuiltInProps.InvokeMember("Item",                               BindingFlags.Default |                               BindingFlags.GetProperty,                               null,oDocBuiltInProps,                               new object[] {strIndex} );   Type typeDocAuthorProp = oDocAuthorProp.GetType();   strValue = typeDocAuthorProp.InvokeMember("Value",                               BindingFlags.Default |                              BindingFlags.GetProperty,                              null,oDocAuthorProp,                              new object[] {} ).ToString();   MessageBox.Show( "The Author is: " + strValue,"Author" );   //Set the Subject property.   strIndex = "Subject";   strValue = "The Subject";   typeDocAuthorProp.InvokeMember("Item",                               BindingFlags.Default |                               BindingFlags.SetProperty,                               null,oDocBuiltInProps,                               new object[] {strIndex,strValue} );			   //Add a property/value pair to the CustomDocumentProperties collection.   oDocCustomProps = oDoc.CustomDocumentProperties;   Type typeDocCustomProps = oDocCustomProps.GetType();   strIndex = "Knowledge Base Article";   strValue = "Q303296";   object[] oArgs = {strIndex,false,                     MsoDocProperties.msoPropertyTypeString,                     strValue};   typeDocCustomProps.InvokeMember("Add",BindingFlags.Default |                               BindingFlags.InvokeMethod, null,                               oDocCustomProps, oArgs );   MessageBox.Show("Select \"Properties\" from the File menu "        + "to view the changes.\nSelect the Summary tab to view "        + "the Subject property and the Custom tab to view the Knowledge"           + "Base Article property.", "Check File Properties",        MessageBoxButtons.OK,MessageBoxIcon.Information);}					
  7. Vaya a la parte superior de la ventana de código y agregue las líneas siguientes al final de la lista de directivas using:
    using Microsoft.Office.Core;using Word = Microsoft.Office.Interop.Word;using System.Reflection;					
  8. Presione la tecla F5 para ejecutar la aplicación.
Nota: las interfaces DocumentProperties y DocumentProperty son interfaces enlazadas en tiempo de ejecución. Para usarlas, debe tratarlas igual que una interfaz IDispatch.
Referencias
Para obtener más información, visite el siguiente sitio Web de Microsoft Developer Network:
Microsoft Office Development with Visual Studio
http://msdn2.microsoft.com/en-us/library/aa188489(office.10).aspx
Para obtener información adicional al respecto, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
303294 Cómo utilizar Automatización para obtener y configurar propiedades de documentos de Office con Visual Basic .NET
xl2003 ppt2003 wd2003
Propiedades

Id. de artículo: 303296 - Última revisión: 01/17/2007 08:46:23 - Revisión: 6.2

  • Microsoft Visual C# .NET 2003 Standard Edition
  • Microsoft Visual C# .NET 2002 Standard Edition
  • Microsoft Office Excel 2003
  • Microsoft Excel 2002 Standard Edition
  • Microsoft Office PowerPoint 2003
  • Microsoft PowerPoint 2002 Standard Edition
  • Microsoft Office Word 2003
  • Microsoft Word 2002 Standard Edition
  • kbpia kbautomation kbhowto KB303296
Comentarios