Python re 模块中,如何使用反斜杠 “\“分割字符串?

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 字符串,则会出现错误信息。示例代码如下:

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
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))
  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值