Python 語言使用反斜杠(\)作為轉義符,對一些字符進行轉義(escape),例如 "\n" "\r\n" 等。所以當 Python 字符串中如果出現反斜杠,則會自動轉義其后的字符。但這會導致一個問題,就是,如果只是把反斜杠作為字符字面(liberal)意義,應該如何處理?
如果不使用 re 模塊(regular expression module),在 Python 字符串中,使用兩個反斜杠轉義,即可表示一個反斜杠。示例代碼如下:
import sys # backslash escape
enter = "\r\n" if sys.platform == "win32" else "\n"
# backslash liberal
backslash_liberal = "\\"
此時,如果使用 Python 字符的 split 方法,用兩個反斜杠作為分割符,是沒有問題的。示例代碼如下:
# Use str type's split() method
print("aa\\bb".split("\\"))
但是如果使用 re 模塊的 split() 方法,依舊使用兩個反斜杠,去分割 Python 字符串,則會出現錯誤信息。示例代碼如下:
import re s = "aa\\bb"
try: re.split("\\", s) except Exception as e: print("error:", e)
這個錯誤的原因是 re 模塊中,也將反斜杠作為轉義字符,而導致的。具體來說,當輸入兩個反斜杠時,兩個反斜杠首先在 Python 解釋器進行轉義,變成一個反斜杠,然后將這一個反斜杠輸入到 re 模塊中,而此時 re 模塊找不到相應的有效轉義結尾,所以會出現錯誤信息 “bad escape (end of pattern) at position 0” (Python 3.8)。
常用的解決方法有兩種方式:
一是使用四個反斜杠 "\\\\" ;二是使用原始字符串(raw string),即 r"\\"。示例代碼如下:
print("Solution 1: ", re.split("\\\\", s)) print("Solution 2: ", re.split(r"\\", s))
參考資料
[1] Regular Expressions: Regexes in Python (Part 1). https://realpython.com/regex-python/