是否有可能在Python中将长行分成多行

时间:2010-11-13 12:17:05

标签: python

就像C一样,你可以将一条长线分成多条短线。但在Python中,如果我这样做,会出现缩进错误......是否可能?

7 个答案:

答案 0 :(得分:569)

来自PEP 8 - Style Guide for Python Code

  

包装长行的首选方法是使用Python的隐含行   在括号,括号和括号内继续。如果有必要,你   可以在表达式周围添加一对额外的括号,但有时候   使用反斜杠看起来更好。确保缩进续行   适当。

隐式线路延续的示例:

a = some_function(
    '1' + '2' + '3' - '4')

关于二元运算符周围的换行主题,接着说: -

  

几十年来,推荐的风格是在二元运算符之后打破。   但这会以两种方式损害可读性:运算符往往分散在屏幕上的不同列中,并且每个运算符都会从其操作数移到上一行。

     

在Python代码中,只要约定在本地一致,就允许在二元运算符之前或之后中断。对于新代码,建议使用Knuth的样式(在运算符之前换行)。

显式续行的示例:

a = '1'   \
    + '2' \
    + '3' \
    - '4'

答案 1 :(得分:201)

有多种方法可以做到。

1)。长篇陈述:

>>> def print_something():
         print 'This is a really long line,', \
               'but we can make it across multiple lines.'

2)。使用括号:

>>> def print_something():
        print ('Wow, this also works?',
               'I never knew!')

3)。再次使用\

>>> x = 10
>>> if x == 10 or x > 0 or \
       x < 100:
       print 'True'

引用PEP8

  

长包裹的首选方式   line是使用Python的暗示   括号,括号和括号内的行继续。如有必要,   你可以在表达式周围添加一对额外的括号,但是   有时使用反斜杠看起来更好。确保缩进续行   适当。打破二进制文件的首选位置   运算符运算符之后,而不是之前。

答案 2 :(得分:24)

如果要为变量指定长str,可以按如下方式进行:

net_weights_pathname = (
    '/home/acgtyrant/BigDatas/'
    'model_configs/lenet_iter_10000.caffemodel')

不要添加任何逗号,否则你会得到一个包含许多strs的元组!

答案 3 :(得分:15)

它也适用于Python:

>>> 1+\
      2+\
3
6
>>> (1+
          2+
 3)
6

答案 4 :(得分:12)

当尝试输入连续文本(例如,查询)时,不要在行尾添加逗号,否则您将获得字符串列表而不是一个长字符串:

queryText= "SELECT * FROM TABLE1 AS T1"\
"JOIN TABLE2 AS T2 ON T1.SOMETHING = T2.SOMETHING"\
"JOIN TABLE3 AS T3 ON T3.SOMETHING = T2.SOMETHING"\
"WHERE SOMETHING BETWEEN <WHATEVER> AND <WHATEVER ELSE>"\
"ORDER BY WHATEVERS DESC"
有点像那样。

acgtyrant有这样的评论,抱歉,没有看到。 :/

答案 5 :(得分:8)

据我所知,可以做到。对于三引号字符串("""like this"""),Python具有隐式行连续(括号内,括号和字符串),并且连续行的缩进并不重要。有关详细信息,您可以阅读python.org上的this词法分析文章。

答案 6 :(得分:4)

数据库相关代码在多行中看起来更容易,由一对三引号括起来:

SQL = """SELECT
            id, 
            fld_1, 
            fld_2, 
            fld_3, 
            ...... 
         FROM some_tbl"""

比以下一条巨大的长线:

SQL = "SELECT id, fld_1, fld_2, fld_3, .................................... FROM some_tbl"