6.7 实践项目 作为实践,编程完成下列任务。 表格打印 编写一个名为 printTable()的函数,它接受字符串的列表的列表,将它显示在组 织良好的表格中,每列右对齐。假定所有内层列表都包含同样数目的字符串。例如, 该值可能看起来像这样: tableData = [['apples', 'oranges', 'cherries', 'banana'], ['Alice', 'Bob', 'Carol', 'David'], ['dogs', 'cats', 'moose', 'goose']] 你的 printTable()函数将打印出: 提示:你的代码首先必须找到每个内层列表中最长的字符串,这样整列就有足够的宽度以 放下所有字符串。你可以将每一列的最大宽度,保存为一个整数的列表。printTable()函 数的开始可以是 colWidths = [0] * len(tableData),这创建了一个列表,它包含了一些 0, 数目与 tableData 中内层列表的数目相同。这样,colWidths[0]就可以保存 tableData[0]中 最长字符串的宽度,colWidths[1]就可以保存 tableData[1]中最长字符串的宽度,以此类推。 然后可以找到colWidths 列表中最大的值,决定将什么整数宽度传递给rjust()字符串方法。
tableData = \
[['apples', 'oranges', 'cherries', 'banana'], #【0,0】【0,1】【0,2】【0,3】
['Alice', 'Bob', 'Carol', 'David'], #【1,0】【1,1】【1,2】【1,3】
['dogs', 'cats', 'moose', 'goose']] #【2,0】【2,1】【2,2】【2,3】
# 你的printTable()函数将打印出:
# apples Alice dogs
# oranges Bob cats
# cherries Carol moose
# banana David goose
def printTable(test):
length_list = []
for k in range(len(test)):
length = 0
for v in range(len(test[0])):
if len(test[k][v]) >length:
length = len(test[k][v])
length_list.append(length)
for k in range(len(test[0])):
for v in range(len(test)):
if v < 1:
print(test[v][k].rjust(length_list[v]),end=' ')
else:
print(test[v][k].ljust(length_list[v]),end=' ')
print()
printTable(tableData)