在Python中,我正在写一个代码如下的文本文件:
f.write(filename + type + size + modified)
当然输出看起来很难看:
C:/Config/ControlSet/__db.006 file 56 KB 2012-Apr-30 10:00:46.467 AM
C:/Config/ControlSet dir 68881 KB 2012-Apr-30 10:00:46.396 AM
C:/Config/DataStore.avlocate file 0 KB 2012-Apr-30 09:57:42.440 AM
C:/Config/DataStoreLocate.bak file 0 KB 2012-Apr-30 09:57:42.470 AM
C:/Config/DeviceConnections/devconn.bak file 41 KB 2012-Apr-30 10:39:50.181 AM
C:/Config/DeviceConnections/devconn.cfg file 41 KB 2012-May-29 10:12:45.288 AM
但是我想对齐这些条目,看起来像这样:
C:/Config/ControlSet/__db.006 file 56 KB 2012-Apr-30 10:00:46.467 AM
C:/Config/ControlSet dir 68881 KB 2012-Apr-30 10:00:46.396 AM
C:/Config/DataStore.avlocate file 0 KB 2012-Apr-30 09:57:42.440 AM
C:/Config/DataStoreLocate.bak file 0 KB 2012-Apr-30 09:57:42.470 AM
C:/Config/DeviceConnections/devconn.bak file 41 KB 2012-Apr-30 10:39:50.181 AM
C:/Config/DeviceConnections/devconn.cfg file 41 KB 2012-May-29 10:12:45.288 AM
我的问题类似于this question,但我不知道文件名预先有多长。我该怎么做呢?
答案 0 :(得分:25)
如果您可以先获取所有文件名列表,那么您可以执行以下操作:
max_width = max(len(filename) for filename in filenames)
for filename in filenames:
f.write(filename.ljust(max_width+1)+..whatever else..)
如果你不能首先获得所有文件名的列表,那么就无法确保所有文件名都排成一行,因为没有办法知道你以后是否会得到一个名字很长的文件。 / p>
在这种情况下,我通常会假设N列通常已足够,对于某些N,在这种情况下,您可以执行以下操作:
f.write('%-40s %6s %10s %2s\n' % (filename, type, size, modified))
答案 1 :(得分:12)
我认为您所寻找的是str.ljust()方法,也可能是str.rjust()。
正如文档中所述,如果原始字符串太长,则会返回原始字符串,因此您永远不会截断任何数据,但您必须提前找出最长的字符串才能获得非常完美的格式。我建议只使用一个相当大的数字值,除非它必须是完美的。
像...一样的东西。
f.write(
"{0} {1} {2} {3}".format(
filename.ljust(max_filename),
type.rjust(max_type),
size.rjust(max_size),
modified.rjust(max_modified)
)
)
会做到这一点。