从技术上讲,任何奇数个反斜杠,如文档中所述。
>>> r'\'
File "<stdin>", line 1
r'\'
^
SyntaxError: EOL while scanning string literal
>>> r'\\'
'\\\\'
>>> r'\\\'
File "<stdin>", line 1
r'\\\'
^
SyntaxError: EOL while scanning string literal
解析器似乎只能将原始字符串中的反斜杠视为常规字符(原始字符串不就是这样吗?),但我可能忽略了一些明显的东西。
关于python原始字符串的所有误解是,大多数人认为反斜杠(在原始字符串中)只是一个普通字符。事实并非如此。理解这段python教程的关键是:
当有'r'或'r'前缀时,字母a
反斜杠包含在字符串中而不更改,并且所有
反斜杠留在字符串中
所以任何跟在反斜杠后面的字符都是原始字符串的一部分。一旦解析器输入一个原始字符串(非Unicode字符串)并遇到一个反斜杠,它就知道有两个字符(一个反斜杠和后面的一个字符)。
这种方式:
R 'abc\d'由a, b, c, \, d组成
R 'abc 'd'由a, b, c, \, ', d组成
R 'abc\ "由a, b, c, \, '组成
and:
R 'abc\'由a, b, c, \组成,'但现在没有终止引号了。
最后一个案例表明,根据文档,现在一个解析器无法找到结束引号,因为你看到上面的最后一个引号是字符串的一部分,即反斜杠不能在这里最后,因为它将“吞噬”字符串结束字符。
关于python原始字符串的所有误解是,大多数人认为反斜杠(在原始字符串中)只是一个普通字符。事实并非如此。理解这段python教程的关键是:
当有'r'或'r'前缀时,字母a
反斜杠包含在字符串中而不更改,并且所有
反斜杠留在字符串中
所以任何跟在反斜杠后面的字符都是原始字符串的一部分。一旦解析器输入一个原始字符串(非Unicode字符串)并遇到一个反斜杠,它就知道有两个字符(一个反斜杠和后面的一个字符)。
这种方式:
R 'abc\d'由a, b, c, \, d组成
R 'abc 'd'由a, b, c, \, ', d组成
R 'abc\ "由a, b, c, \, '组成
and:
R 'abc\'由a, b, c, \组成,'但现在没有终止引号了。
最后一个案例表明,根据文档,现在一个解析器无法找到结束引号,因为你看到上面的最后一个引号是字符串的一部分,即反斜杠不能在这里最后,因为它将“吞噬”字符串结束字符。