Crear una Tabla

Aspose.Words permite a los usuarios crear tablas en un documento desde cero y proporciona varios métodos diferentes para hacerlo. Este artículo presenta detalles sobre cómo agregar tablas formateadas a su documento usando cada método, así como una comparación de cada método al final del artículo.

Estilos de Tabla Predeterminados

La tabla recién creada tiene valores predeterminados similares a los utilizados en Microsoft Word:

Single
Black
True

Crea una tabla con DocumentBuilder

En Aspose.Words, los usuarios pueden crear una tabla en un documento usando DocumentBuilder. El algoritmo básico para crear una tabla es el siguiente:

  1. Comience la tabla con StartTable
  2. Agregue una celda a la tabla usando InsertCell; esto inicia automáticamente una nueva fila
  3. Opcionalmente, use la propiedad CellFormat para especificar el formato de celda
  4. Inserte el contenido de la celda utilizando los métodos DocumentBuilder apropiados, como Writeln, InsertImage y otros
  5. Repita los pasos 2-4 hasta que se complete la fila
  6. Llame a EndRow para finalizar la fila actual
  7. Opcionalmente, use la propiedad RowFormat para especificar el formato de fila
  8. Repita los pasos 2-7 hasta que se complete la tabla
  9. Llame a EndTable para terminar de construir la tabla

El proceso de creación de una tabla se puede ver claramente en la siguiente imagen:

creating-table-process

El siguiente ejemplo de código muestra cómo crear una tabla simple usando DocumentBuilder con formato predeterminado:

El siguiente ejemplo de código muestra cómo crear una tabla formateada usando DocumentBuilder:

El siguiente ejemplo de código muestra cómo insertar una tabla anidada usando DocumentBuilder:

Crear una tabla a través de DOM (Document Object Model)

Puede insertar tablas directamente en el DOM agregando un nuevo nodo Table en una posición específica.

Tenga en cuenta que inmediatamente después de la creación del nodo de la tabla, la tabla misma estará completamente vacía, es decir, aún no contiene filas ni celdas. Para insertar filas y celdas en una tabla, agregue los nodos secundarios Row y Cell apropiados al DOM.

El siguiente ejemplo de código muestra cómo crear una nueva tabla desde cero agregando los nodos secundarios apropiados al árbol de documentos:

Crear una tabla a partir de HTML

Aspose.Words admite la inserción de contenido en un documento desde una fuente HTML utilizando el método InsertHtml. La entrada puede ser una página HTML completa o solo un fragmento parcial.

Usando el método InsertHtml, los usuarios pueden insertar tablas en el documento a través de etiquetas de tabla como <table>, <tr>, <td>.

El siguiente ejemplo de código muestra cómo insertar una tabla en un documento a partir de una cadena que contiene etiquetas HTML:

Insertar una copia de una tabla existente

A menudo, hay ocasiones en las que necesita crear una tabla basada en una tabla ya existente en un documento. La forma más sencilla de duplicar una tabla conservando todo el formato es clonar el nodo de la tabla utilizando el método Clone.

La misma técnica se puede utilizar para agregar copias de una fila o celda existente a una tabla.

El siguiente ejemplo de código muestra cómo duplicar una tabla usando constructores de nodos:

El siguiente ejemplo de código muestra cómo clonar la última fila de una tabla y anexarla a la tabla:

Si está buscando crear tablas en un documento que crezcan dinámicamente con cada registro de su fuente de datos, entonces no se recomienda el método anterior. En cambio, la salida deseada se logra más fácilmente usando Mail merge con regiones. Puede obtener más información sobre esta técnica en el Mail Merge con Regiones sección.

Compare Formas de Crear una Tabla

Aspose.Words proporciona varios métodos para crear nuevas tablas en un documento. Cada método tiene sus propias ventajas y desventajas, por lo que la elección de cuál usar a menudo depende de la situación específica.

Echemos un vistazo más de cerca a estas formas de crear tablas y comparemos sus pros y sus contras:

Método Desventajas
DocumentBuilder El método estándar para insertar tablas y otro contenido de documentos
Se adapta mejor al código circundante que crea e inserta nodos directamente en el DOM sin usar un DocumentBuilder La tabla se crea “vacía”: antes de realizar la mayoría de las operaciones, debe llamar a EnsureMinimum para crear los nodos secundarios faltantes
Puede crear una nueva tabla desde la fuente HTML usando etiquetas como <table>, <tr>, <td>
Puede crear una copia de una tabla existente conservando todo el formato de fila y celda Los nodos secundarios apropiados deben eliminarse antes de que la tabla esté lista para su uso