考虑到:

e = 'a' + 'b' + 'c' + 'd'

我怎么把上面的内容写成两行呢?

e = 'a' + 'b' +
    'c' + 'd'

当前回答

如果你想因为一个很长的字符串文字而打断你的行,你可以把这个字符串分解成几个部分:

long_string = "a very long string"
print("a very long string")

将被

long_string = (
  "a "
  "very "
  "long "
  "string"
)
print(
  "a "
  "very "
  "long "
  "string"
)

两个print语句的输出:

一条很长的弦

注意做作中的圆括号。

还需要注意的是,将字面值字符串分解为多个部分,允许只在字符串的部分使用字面值前缀,并混合使用分隔符:

s = (
  '''2+2='''
  f"{2+2}"
)

其他回答

来自PEP 8——Python代码风格指南:

对长行进行换行的首选方法是在括号、大括号和大括号内使用Python隐含的行延续。长行可以通过将表达式括在圆括号中来拆分为多行。这些应该优先于使用反斜杠来续行。

有时反斜杠仍然是合适的。例如,长且多的with-语句不能使用隐式延续,因此反斜杠是可以接受的:

以open('/path/to/some/file/you/want/to/read')为file_1, \ 打开('/path/to/some/file/being/written', 'w') as file_2: file_2.write (file_1.read ()) 另一种情况是使用assert语句。

确保适当缩进继续行。对二进制操作符进行换行的最佳位置是在操作符之后,而不是在它之前。一些例子:

类矩形(Blob): 定义__init__(self, width, height, color='black', emphasis=None, highlight=0): If (width == 0 and height == 0 and Color == 'red'和emphasis == 'strong' or 100): 抛出ValueError("抱歉,你输了") 如果width == 0 and height == 0 and (color == 'red' or 重点是None): 抛出ValueError("I don't think so - values are %s, %s" (宽度、高度)) Blob。__init__(self, width, height, 颜色,重点,高亮)file_2.write(file_1.read())

PEP8现在推荐数学家和他们的出版商使用相反的约定(用于二进制运算的中断)来提高可读性。

Donald Knuth在二进制运算符之前中断的风格使运算符垂直对齐,从而减少了眼睛在确定添加和减去哪些项时的工作量。

在二进制操作符之前还是之后换行?:

Donald Knuth在他的计算机和排版系列中解释了传统的规则:“尽管段落中的公式总是在二进制操作和关系之后中断,但显示的公式总是在二进制操作之前中断”[3]。

遵循数学的传统通常会产生更可读的代码:

# Yes:容易匹配操作符和操作数

income = (gross_wages
          + taxable_interest
          + (dividends - qualified_dividends)
          - ira_deduction
          - student_loan_interest)

在Python代码中,只要约定在局部一致,就允许在二进制操作符之前或之后进行换行。对于新代码,建议使用Knuth的风格。

[3]:唐纳德·克努斯的《教科书》,195页和196页

还可以在多行中中断方法(obj.method())的调用。

将命令括在圆括号“()”中,并跨越多行:

> res = (some_object
         .apply(args)
         .filter()
         .values)

例如,我发现在链上调用Pandas/Holoviews对象方法很有用。

在行末加一个\,或将语句括在parens(..)中。. 来自IBM的:

b = ((i1 < 20) and
     (i2 < 30) and
     (i3 < 40))

or

b = (i1 < 20) and \
    (i2 < 30) and \
    (i3 < 40)

这可能不是python的方式,但我通常使用带有join函数的列表来编写长字符串,就像SQL查询一样:

query = " ".join([
    'SELECT * FROM "TableName"',
    'WHERE "SomeColumn1"=VALUE',
    'ORDER BY "SomeColumn2"',
    'LIMIT 5;'
])

使用反斜杠来结束一行的危险在于,如果在反斜杠之后添加了空格(当然,这很难看到),反斜杠就不再起到您所认为的作用了。

参见Python习语和反习语(适用于Python 2或Python 3)了解更多信息。