假设变量“info”具有以下字符串:
abc: 234234
aadfa: 235345
bcsd: 992
在python中,将“信息”格式化为:
abc: 234234
aadfa: 235345
bcsd: 992
假设变量“info”具有以下字符串:
abc: 234234
aadfa: 235345
bcsd: 992
在python中,将“信息”格式化为:
abc: 234234
aadfa: 235345
bcsd: 992
这将起作用:
>>> 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 个字符格式化该参数。
窃取@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
希望以下代码有所帮助。
>>> 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]
您可以控制最终长度的制作方式。