rows property
Table.rows property
Provides typed access to the rows of the table.
@property
def rows(self) -> aspose.words.tables.RowCollection:
...
Examples
Shows how to iterate through all tables in the document and print the contents of each cell.
doc = aw.Document(file_name=MY_DIR + 'Tables.docx')
tables = doc.first_section.body.tables
self.assertEqual(2, len(list(tables)))
i = 0
while i < tables.count:
print(f'Start of Table {i}')
rows = tables[i].rows
# We can use the "ToArray" method on a row collection to clone it into an array.
self.assertSequenceEqual(list(rows), list(rows))
self.assertNotEqual(rows, list(rows))
j = 0
while j < rows.count:
print(f'\tStart of Row {j}')
cells = rows[j].cells
# We can use the "ToArray" method on a cell collection to clone it into an array.
self.assertSequenceEqual(list(cells), list(cells))
self.assertNotEqual(cells, list(cells))
k = 0
while k < cells.count:
cell_text = cells[k].to_string(save_format=aw.SaveFormat.TEXT).strip()
print(f'\t\tContents of Cell:{k} = "{cell_text}"')
k += 1
print(f'\tEnd of Row {j}')
j += 1
print(f'End of Table {i}\n')
i += 1
Shows how to combine the rows from two tables into one.
doc = aw.Document(file_name=MY_DIR + 'Tables.docx')
# Below are two ways of getting a table from a document.
# 1 - From the "Tables" collection of a Body node:
first_table = doc.first_section.body.tables[0]
# 2 - Using the "GetChild" method:
second_table = doc.get_child(aw.NodeType.TABLE, 1, True).as_table()
# Append all rows from the current table to the next.
while second_table.has_child_nodes:
first_table.rows.add(second_table.first_row)
# Remove the empty table container.
second_table.remove()
doc.save(file_name=ARTIFACTS_DIR + 'Table.CombineTables.docx')
See Also
- module aspose.words.tables
- class Table