Adición de elementos XML personalizados a documentos mediante complementos de VSTO
Puede almacenar datos XML en los siguientes tipos de documentos creando un elemento XML personalizado en un complemento de VSTO:
Un libro de Microsoft Office Excel.
Un documento de Microsoft Office Word.
Una presentación de Microsoft Office PowerPoint.
Para obtener más información, consulte Información general sobre elementos XML personalizados.
Aplicación: la información de este tema se aplica a los proyectos de nivel de aplicación de Excel, PowerPoint y Word. Para obtener más información, consulte Características disponibles por aplicación de Office lication y tipo de proyecto.
Para agregar un elemento XML personalizado a un libro de Excel
Agregue un nuevo objeto CustomXMLPart a la colección CustomXMLParts del libro. CustomXMLPart contiene la cadena XML que desea almacenar en el libro.
En el ejemplo de código siguiente se agrega un elemento XML personalizado al libro especificado.
private void AddCustomXmlPartToWorkbook(Excel.Workbook workbook) { string xmlString = "<?xml version=\"1.0\" encoding=\"utf-8\" ?>" + "<employees xmlns=\"http://schemas.microsoft.com/vsto/samples\">" + "<employee>" + "<name>Karina Leal</name>" + "<hireDate>1999-04-01</hireDate>" + "<title>Manager</title>" + "</employee>" + "</employees>"; Office.CustomXMLPart employeeXMLPart = workbook.CustomXMLParts.Add(xmlString, missing); }
Agregue el
AddCustomXmlPartToWorkbook
método a laThisAddIn
clase en un proyecto de complemento de VSTO para Excel.Llame al método desde otro código del proyecto. Por ejemplo, para crear el elemento XML personalizado cuando el usuario abre un libro, llame al método desde un controlador de eventos para el evento WorkbookOpen .
Para agregar un elemento XML personalizado a un documento de Word
Agregue un nuevo objeto CustomXMLPart a la colección CustomXMLParts del documento. CustomXMLPart contiene la cadena XML que desea almacenar en el documento.
En el ejemplo de código siguiente se agrega un elemento XML personalizado al documento especificado.
private void AddCustomXmlPartToActiveDocument(Word.Document document) { string xmlString = "<?xml version=\"1.0\" encoding=\"utf-8\" ?>" + "<employees xmlns=\"http://schemas.microsoft.com/vsto/samples\">" + "<employee>" + "<name>Karina Leal</name>" + "<hireDate>1999-04-01</hireDate>" + "<title>Manager</title>" + "</employee>" + "</employees>"; Office.CustomXMLPart employeeXMLPart = document.CustomXMLParts.Add(xmlString, missing); }
Agregue el
AddCustomXmlPartToDocument
método a laThisAddIn
clase en un proyecto de complemento de VSTO para Word.Llame al método desde otro código del proyecto. Por ejemplo, para crear el elemento XML personalizado cuando el usuario abre un documento, llame al método desde un controlador de eventos para el evento DocumentOpen .
Para agregar un elemento XML personalizado a una presentación de PowerPoint
Agregue un nuevo CustomXMLPart objeto a la colección Microsoft.Office.Interop.PowerPoint._Presentation.CustomXMLParts en la presentación. CustomXMLPart contiene la cadena XML que desea almacenar en la presentación.
En el ejemplo de código siguiente se agrega un elemento XML personalizado a la presentación especificada.
private void AddCustomXmlPartToPresentation(PowerPoint.Presentation presentation) { string xmlString = "<?xml version=\"1.0\" encoding=\"utf-8\" ?>" + "<employees xmlns=\"http://schemas.microsoft.com/vsto/samples\">" + "<employee>" + "<name>Karina Leal</name>" + "<hireDate>1999-04-01</hireDate>" + "<title>Manager</title>" + "</employee>" + "</employees>"; Office.CustomXMLPart employeeXMLPart = presentation.CustomXMLParts.Add(xmlString, missing); }
Agregue el
AddCustomXmlPartToPresentation
método a laThisAddIn
clase en un proyecto de complemento de VSTO para PowerPoint.Llame al método desde otro código del proyecto. Por ejemplo, para crear el elemento XML personalizado cuando el usuario abre una presentación, llame al método desde un controlador de eventos para el evento Microsoft.Office.Interop.PowerPoint.EApplication_Event.AfterPresentationOpen .
Programación sólida
Para simplificar, este ejemplo usa una cadena XML que se define como una variable local en el método. Normalmente, debe obtener el XML desde un origen externo, como un archivo o una base de datos.