从here
中找到此代码段后'{0: <16}'.format('Hi')
我能够正确填充琴弦 - 这就是我所追求的。 我已经编写了一个处理多行字符串的函数,但我感觉有更快,更Pythonic的方法: 字符串用&#34;填充。&#34;仅作为一个例子。
#!/usr/bin/python
def r_pad_string (s):
listy = s.splitlines()
w = 0
ss = ""
for i in range(0, len(listy)):
l = len(str(listy[i]))
if l > w:
w = l
for i in range(0, len(listy)):
pad = str(listy[i]).ljust(w, ".")
ss += pad + "\n"
return ss
myStr1 = " ######\n" \
" ########\n" \
"## ## ##\n" \
"## ### ###\n" \
"##########\n" \
"##########\n" \
"## ## ##\n" \
"# # #"
myStr2 = """Spoons
are
great!!!"""
print r_pad_string(myStr1)
print r_pad_string(myStr2)
答案 0 :(得分:2)
def r_pad_string2(s, fillchar='.'):
lines = s.splitlines()
max_len = max(len(l) for l in lines)
return '\n'.join(l.ljust(max_len, fillchar) for l in lines)
定时:
In [12]: %timeit r_pad_string(myStr1)
100000 loops, best of 3: 5.38 µs per loop
In [13]: %timeit r_pad_string2(myStr1)
100000 loops, best of 3: 3.43 µs per loop
In [14]: %timeit r_pad_string(myStr2)
100000 loops, best of 3: 2.48 µs per loop
In [15]: %timeit r_pad_string2(myStr2)
1000000 loops, best of 3: 1.9 µs per loop
所以它的速度并不是那么快,但眼睛容易多了。
答案 1 :(得分:1)
max
- 函数存在,这消除了您的第一个循环。 join
可用于再次将线条粘在一起:
def r_pad_string(s):
lines = s.splitlines()
width = max(len(l) for l in lines)
return "\n".join(
line.ljust(width, ".")
for line in lines
)
一般说明:缩进应该是每个级别4个空格,并且应该说出变量名称。迭代线可以直接完成,而不是在索引的帮助下。当它确实有助于可读性时,仅使用空行。 listy
的元素已经是字符串,所以不需要一遍又一遍地将它们转换为字符串。