建立表格

Aspose.Words 允許使用者從頭開始建立文件中的表格,並提供幾種不同的方法來做。 這篇文章會提供如何在每個方法中加入格式化的表格到你的文件的細節,並會在文章的最後比較每個方法。

預設表格樣式

新建立的表格具有與在 Microsoft Word 中使用的值類似的預設值。

桌面属性 預設在 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

透過DocumentBuilder建立一張表格

在 Aspose.Words 中,使用者可以用 DocumentBuilder 在文件中建立一個表格。 建立表格的基本演算法如下:

  1. 開始該表,以 StartTable 開頭
  2. 透過 InsertCell 將一列新增至表格中–這會自動開始新的資料列。 3。 可選地,使用 CellFormat 屬性來指定單元格格式化
  3. 透過合適的 DocumentBuilder 方法插入細胞內容,例如 WritelnInsertImage 等。
  4. 重覆步驟2-4,直到該列完成
  5. 呼叫 EndRow 來結束當前的列
  6. 工 作 可選地,使用 RowFormat 屬性來指定列格式
  7. 在完成桌子之前重複步驟2到7
  8. 打電話給 EndTable 完成製作桌子。

建立表格的過程可以在下列圖片中清楚地看到:

creating-table-process

接下來的程式碼範例顯示了如何使用 DocumentBuilder 來建立一個簡單的表格,並使用預設的格式:

接下來的程式碼範例示範了如何透過 DocumentBuilder 建立格式化表:

接下來的程式碼範例示範了如何透過 DocumentBuilder 插入嵌套的表格。

透過 DOM ( Document Object Model )建立資料表

您可以直接在 DOM 中插入資料表,方法是將新的 Table 節點加入特定位置。

請注意,在表結點創建後立即,表本身將完全是空的,也就是它尚未包含行和單元格。 若要將列和セル插入到表中,請將適當的 RowCell 子節點新增到 DOM。

接下來這段程式碼示例展示了如何從頭建立新的表格,透過向文件樹中加入適當的子節點:

從 HTML 建立表格

Aspose.Words 支援透過 InsertHtml 方法從 HTML 來源將內容插入到文件中。 輸入可以是完整的 HTML 頁面,也可以是部分片段。

使用 InsertHtml 方法,使用者可以用像 <table><tr><td> 的表格標籤來在文件中插入表格。

以下範例展示了如何從包含 HTML 標籤的文字中插入一張表格到文件中:

插入現有表格的副本

在您需要根據一張已經存在的文件表格來建立新的表格時,經常會碰到這種情況。 最簡單的複製桌面方法,同時保留所有格式,就是透過 Clone 方法複製Table節點。

相同的技術可用於將現有的行或列複製到表格中。

以下範例展示了如何使用節點生成器複製一張表格:

以下範例示出了如何複製一張表的最後一行並附加到表中:

如果您正在建立一個由資料源中各筆資料動態成長的文件中的表格,那麼上述方法不建議使用。 取而代之,我們更容易透過使用具有區域之 Mail merge 來達到預期的輸出。 您可以在 Mail Merge with Regions部分中了解更多有關此技術的資訊。

比較創建一張表格的方式

Aspose.Words 提供幾個方法來在文件中建立新表。 每個方法都有其優缺點,因此選擇要使用的方法通常取決於具體的情況。

讓我們更仔細地看這些創造表格的方式,並比較它们的優缺點:

方法 優點 缺點
Via DocumentBuilder 插入表格和其他文書內容的標準方法 有時很難在一個建造器實例下同時建立許多不同的樣式。
透過 DOM 直接將節點插入到 DOM 中,而不使用 DocumentBuilder 的程式碼會更好。 該表格是空的:在執行大多數作業之前,您必須呼叫 EnsureMinimum 以建立任何缺失的子節點。
來自HTML 可以用標籤 <table><tr><td> 等從 HTML 來源來建立新的資料表。 並非所有可能的 Microsoft Word 表格格式都能適用於 HTML
複製現有的資料表 您可以建立一個現有資料表的複製,同時保留所有列和格子的格式。 在使用前必須先移除適當的子節點。