向右填充多行字符串

Pad right multi-line string

here

中找到此代码段后
'{0: <16}'.format('Hi')

我能够正确填充字符串 - 这正是我所追求的。 我写了一个函数来处理多行字符串,但我觉得有一个更快、更 Pythonic 的方法: 字符串用“.”填充。举个例子。

#!/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)

存在 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的元素已经是字符串了,不用再一遍又一遍的转成字符串了。

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

所以它并没有那么快,但眼睛更舒服。