Introdução e criação de tabelas

Aspose.Words permite aos usuários criar tabelas em um documento do zero e fornece vários métodos diferentes para fazer isso. Este artigo apresenta detalhes sobre como adicionar tabelas formatadas ao seu documento usando cada método, bem como uma comparação de cada método no final do artigo.

Estilos de tabela padrão

A tabela recém-criada recebe valores padrão semelhantes aos usados em Microsoft Word:

Propriedade da tabela Padrão em Aspose.Words
Border Style Single
Border Width 1/2 pt
Border Color Black
Left and Right Padding 5.4 pts
AutoFit Mode AutoFit to Window
Allow AutoFit True

Crie uma tabela com DocumentBuilder

No Aspose.Words, os usuários podem criar uma tabela em um documento usando o DocumentBuilder. O algoritmo básico para criar uma tabela é o seguinte:

  1. Inicie a tabela com StartTable
  2. Adicione uma célula à tabela usando InsertCell – isso inicia automaticamente uma nova linha
  3. Opcionalmente, use a propriedade CellFormat para especificar a formatação da célula
  4. Insira o conteúdo da célula usando os métodos DocumentBuilder apropriados, como Writeln, InsertImage e outros
  5. Repita as etapas 2 a 4 até que a linha esteja completa
  6. Chame EndRow para encerrar a linha atual
  7. Opcionalmente, use a propriedade RowFormat para especificar a formatação de linha
  8. Repita as etapas 2 a 7 até que a tabela esteja completa
  9. Ligue para o EndTable para terminar de construir a mesa

O processo de criação de uma tabela pode ser visto claramente na imagem a seguir:

processo de criação de tabela

O exemplo de código a seguir mostra como criar uma tabela simples usando DocumentBuilder com formatação padrão:

O exemplo de código a seguir mostra como criar uma tabela formatada usando DocumentBuilder:

O exemplo de código a seguir mostra como inserir uma tabela aninhada usando DocumentBuilder:

Crie uma tabela via DOM (Document Object Model)

Você pode inserir tabelas diretamente no DOM adicionando um novo nó Table em uma posição específica.

Observe que imediatamente após a criação do nó da tabela, a própria tabela estará completamente vazia, ou seja, ainda não contém linhas e células. Para inserir linhas e células em uma tabela, adicione os nós filhos Row e Cell apropriados ao DOM.

O exemplo de código a seguir mostra como construir uma nova tabela do zero adicionando os nós filhos apropriados à árvore do documento:

##Create uma tabela de HTML

Aspose.Words suporta a inserção de conteúdo em um documento a partir de uma fonte HTML usando o método InsertHtml. A entrada pode ser uma página HTML completa ou apenas um trecho parcial.

Usando o método InsertHtml, os usuários podem inserir tabelas no documento por meio de tags de tabela como <table>, <tr>, <td>.

O exemplo de código a seguir mostra como inserir uma tabela em um documento a partir de uma string contendo tags HTML:

Insira uma cópia de uma tabela existente

Muitas vezes você precisa criar uma tabela com base em uma tabela já existente em um documento. A maneira mais fácil de duplicar uma tabela mantendo toda a formatação é clonar o nó Tabela usando o método Clone.

A mesma técnica pode ser usada para adicionar cópias de uma linha ou célula existente a uma tabela.

O exemplo de código a seguir mostra como duplicar uma tabela usando construtores de nó:

O exemplo de código a seguir mostra como clonar a última linha de uma tabela e anexá-la à tabela:

Se você deseja criar tabelas em um documento que cresçam dinamicamente com cada registro de sua fonte de dados, o método acima não é recomendado. Em vez disso, o resultado desejado é alcançado mais facilmente usando Mail merge com regiões.

Compare maneiras de criar uma tabela

Aspose.Words fornece vários métodos para criar novas tabelas em um documento. Cada método tem suas próprias vantagens e desvantagens, portanto a escolha de qual usar geralmente depende da situação específica.

Vamos dar uma olhada nessas formas de criar tabelas e comparar seus prós e contras:

Método Vantagens Desvantagens
Através do DocumentBuilder O método padrão para inserir tabelas e outros conteúdos de documentos Às vezes é difícil criar muitas variedades de tabelas ao mesmo tempo com a mesma instância do construtor
Via DOM Adapta-se melhor ao código circundante que cria e insere nós diretamente no DOM sem usar um DocumentBuilder A tabela é criada “vazia”: antes de executar a maioria das operações, você deve chamar EnsureMinimum para criar quaisquer nós filhos ausentes
Do HTML Pode criar uma nova tabela a partir de fonte HTML usando tags como <table>, <tr>, <td> Nem todos os formatos de tabela Microsoft Word possíveis podem ser aplicados ao HTML
Clonando uma tabela existente Você pode criar uma cópia de uma tabela existente, mantendo toda a formatação de linhas e células Os nós filhos apropriados devem ser removidos antes que a tabela esteja pronta para uso