1

假设变量“info”具有以下字符串:

abc: 234234
aadfa: 235345
bcsd: 992

在python中,将“信息”格式化为:

abc:    234234
aadfa:  235345
bcsd:   992
4

3 回答 3

2

这将起作用:

>>> s = """abc: 234234
... aadfa: 235345
... bcsd: 992"""
>>> print s
abc: 234234
aadfa: 235345
bcsd: 992

现在我们可以在新行和空间上拆分以获取每行的每个项目:

>>> pairs = [x.split() for x in s.split('\n') ]
>>> pairs
[['abc:', ' 234234'], ['aadfa:', ' 235345'], ['bcsd:', ' 992']]

现在格式化每个字符串:

>>> for pair in pairs:
...     print '{0:10} {1}'.format(pair[0], pair[1])
...
abc:        234234
aadfa:      235345
bcsd:       992

注意我们如何{0:10}在字符串格式化中使用?这只是意味着用 10 个字符格式化该参数。

于 2013-04-06T01:47:07.223 回答
1

窃取@JoshSmeaton 的变量名:

>>> pairs = map(str.split, text.splitlines())
>>> max_len = max(len(pair[0]) for pair in pairs)
>>> info = '\n'.join('{key:<{indent}}{val}'.format(key=k,
                                                   indent=max_len + 2,
                                                   val=v) for k, v in pairs)
>>> print info
abc:    234234
aadfa:  235345
bcsd:   992
于 2013-04-06T02:02:44.847 回答
0

希望以下代码有所帮助。

>>> import math
>>> info = ["abc: 234234", "aadfa: 235345", "bcsd: 992"]
>>> info = [item.split() for item in info]
>>> maxlen = max([len(item[0]) for item in info])
>>> maxlen = math.ceil(maxlen/8.0)*8
>>> info = [item[0]+" "*(maxlen-len(item[0]))+item[1] for item in info]

您可以控制最终长度的制作方式。

于 2013-04-06T01:58:37.487 回答