4

例如,如果我有

>>> name = f"{os.path.splitext(os.path.basename('/some/long/path/I/donot/need/to/some/config.bs'))[0]}.yaml"
'config.yaml'

因为实际文本很少,所以在 79 个字符之前没有好地方可以换行。看来你不能这样做:

name = f"{os.path.splitext(os.path.basename(
    '/some/long/path/I/donot/need/to/some/config.bs'))[0]}.yaml"

>>> f"{os.path.splitext(os.path.basename(
  File "<stdin>", line 1
    f"{os.path.splitext(os.path.basename(
                                        ^
SyntaxError: EOL while scanning string literal

我唯一能做的就是拆分命令,例如:

>>> fname = '/some/long/path/I/donot/need/to/some/config.bs'
>>> tempname = os.path.splitext(os.path.basename(
...     fname))[0]
>>> name = f'{tempname}.yaml'
>>> name
'config.yaml'

是否有任何其他选项来拆分 f 字符串?

4

1 回答 1

8

是的,您仍然可以使用三引号字符串并以您认为最好的任何方式对其进行拆分。

从 PEP on f-strings

表达式中的前导和尾随空格被忽略

为了便于阅读,表达式中的前导和尾随空格被忽略。这是在评估之前将表达式括在括号中的副产品。

因此,删除前后的任何空格,括号内的额外空格(例如函数调用)和方/大括号也出于同样的原因没有区别。所以这:

name = f"""{
    os.path.splitext(
        os.path.basename('/some/long/path/I/donot/need/to/some/config.bs')
    )[0]}.yaml"""

应该仍然产生预期的结果。以您认为最好的方式格式化它。

尽管有人可以成功地争辩说您可以通过其他一些步骤来减少所有内容:

# not using fully qualified name
from os.path import splitext, basename

fname = '/some/long/path/I/donot/need/to/some/config.bs'
name = f"{splitext(basename(fname))[0].yaml"

选择最终是你的。

于 2017-09-29T19:40:28.640 回答