我正在尝试打印几个列表(等长)作为表的列。
我正在从.txt文件中读取数据,并且在代码的末尾,我有5个列表,我想打印为列分隔但是空格。
答案 0 :(得分:7)
我将向您展示一个3列表模拟:
>>> l1 = ['a', 'b', 'c']
>>> l2 = ['1', '2', '3']
>>> l3 = ['x', 'y', 'z']
>>> for row in zip(l1, l2, l3):
... print ' '.join(row)
a 1 x
b 2 y
c 3 z
答案 1 :(得分:6)
您可以使用我的包beautifultable。它支持按行或列添加数据,甚至可以混合两种方法。您可以插入,删除,更新任何行或列。
>>> from beautifultable import BeautifulTable
>>> table = BeautifulTable()
>>> table.column_headers = ["name", "rank", "gender"]
>>> table.append_row(["Jacob", 1, "boy"])
>>> table.append_row(["Isabella", 1, "girl"])
>>> table.append_row(["Ethan", 2, "boy"])
>>> table.append_row(["Sophia", 2, "girl"])
>>> table.append_row(["Michael", 3, "boy"])
>>> print(table)
+----------+------+--------+
| name | rank | gender |
+----------+------+--------+
| Jacob | 1 | boy |
+----------+------+--------+
| Isabella | 1 | girl |
+----------+------+--------+
| Ethan | 2 | boy |
+----------+------+--------+
| Sophia | 2 | girl |
+----------+------+--------+
| Michael | 3 | boy |
+----------+------+--------+
玩得开心
答案 2 :(得分:1)
确认您有一份清单清单:
for L in list_of_lists:
print " ".join(L)
str.join(iterable)
函数,通过给定的字符串连接iterable的组件。
因此," ".join([1, 2, 3])
变为“1 2 3”。
如果我可能误解了这个问题,并且每个list
应该是一列:
for T in zip(list1, list2, list3, list4, list5):
print " ".join(T)
zip()
将给定列表合并到一个元组列表中:
>>> zip([1,2,3], [4,5,6], [7,8,9])
[(1, 4, 7), (2, 5, 8), (3, 6, 9)]
干杯!
答案 3 :(得分:0)
for nested_list in big_container_list
print '\t'.join(nested_list)
\t
是制表字符
快速示例:
In [1]: a = [['1','2'],['3','4']]
In [5]: for nested_list in a:
...: print '\t'.join(nested_list)
...:
1 2
3 4
答案 4 :(得分:0)
试用我的library
注意:此答案已经发布在此question和此question上。
我刚刚为此建立了一个图书馆,我认为它真的可以提供帮助。这非常简单,这就是为什么我认为您应该使用它。它称为 TableIT 。
要使用它,请先按照GitHub Page上的下载说明进行操作。
然后将其导入:
import TableIt
然后创建一个列表列表,其中每个内部列表都是一行:
table = [
[4, 3, "Hi"],
[2, 1, 808890312093],
[5, "Hi", "Bye"]
]
然后您要做的就是打印它:
TableIt.printTable(table)
这是您得到的输出:
+--------------------------------------------+
| 4 | 3 | Hi |
| 2 | 1 | 808890312093 |
| 5 | Hi | Bye |
+--------------------------------------------+
如果需要,您可以使用字段名称(如果您不使用字段名称,则不必说useFieldNames = False,因为默认情况下已将其设置为):>
TableIt.printTable(table, useFieldNames=True)
从中您将得到:
+--------------------------------------------+
| 4 | 3 | Hi |
+--------------+--------------+--------------+
| 2 | 1 | 808890312093 |
| 5 | Hi | Bye |
+--------------------------------------------+
还有其他用途,例如,您可以这样做:
import TableIt
myList = [
["Name", "Email"],
["Richard", "richard@fakeemail.com"],
["Tasha", "tash@fakeemail.com"]
]
TableIt.print(myList, useFieldNames=True)
从那开始:
+-----------------------------------------------+
| Name | Email |
+-----------------------+-----------------------+
| Richard | richard@fakeemail.com |
| Tasha | tash@fakeemail.com |
+-----------------------------------------------+
或者您可以这样做:
import TableIt
myList = [
["", "a", "b"],
["x", "a + x", "a + b"],
["z", "a + z", "z + b"]
]
TableIt.printTable(myList, useFieldNames=True)
然后您将得到:
+-----------------------+
| | a | b |
+-------+-------+-------+
| x | a + x | a + b |
| z | a + z | z + b |
+-----------------------+
您还可以使用颜色。
您可以通过使用颜色选项(默认情况下,设置为无)并指定RGB值来使用颜色。
使用上面的示例:
import TableIt
myList = [
["", "a", "b"],
["x", "a + x", "a + b"],
["z", "a + z", "z + b"]
]
TableIt.printTable(myList, useFieldNames=True, color=(26, 156, 171))
那么您将得到:
请注意,打印颜色可能对您不起作用,但它的工作原理与打印彩色文本的其他库完全相同。我已经测试过,每种颜色都能正常工作。如果使用默认的34m
ANSI转义序列,蓝色也不会弄乱(如果您不知道那是什么也没关系)。无论如何,这全都来自于每种颜色都是RGB值而不是系统默认值的事实。
有关更多信息,请检查GitHub Page