python2.7正则匹配中文_Python2.7 转义和正则匹配中文

今天爬虫(新浪微博 个人信息页面)的时候遇到了转义和正则匹配中文出乱码的问题。

先给出要匹配的部分网页源代码如下:

昵称:他们叫我远凸哥哥\r\n\t\t

想要匹配得到的结果是这个人的昵称,即“他们叫我远凸哥哥”

1.转义

比较简单,需要转义的是反斜杠(\)和引号(")

1 >>> content='昵称:他们叫我远凸哥哥\\r\\n\\t\\t'

2 >>> printcontent3 昵称:他们叫我远凸哥哥\r\n\t\t

2. 匹配中文乱码的问题

问题如下:

1 >>> re.findall(r'(?<=昵称:).*?(?=)',content)2 ['\xcb\xfb\xc3\xc7\xbd\xd0\xce\xd2\xd4\xb6\xcd\xb9\xb8\xe7\xb8\xe7']

百度和google了一下,知道了大概思路就是要decode('utf8')。有说pattern要写成u'pattern'的,不过我试了好像没什么用,不知道是不是我用的2.X版本。最后解决办法如下:

1 #! /usr/bin/env python

2 #coding=utf8

3

4 importre5 content6='昵称:他们叫我远凸哥哥\\r\\n\\t\\t'

6 b=re.findall(r'(?<=昵称:).*?(?=)',content6)7 print b[0].decode('utf8')8 他们叫我远凸哥哥

不知道大家有什么更好的写法,网上的写法试了好几种,我这里都是不行的。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值