Python 中正则匹配问题

2018-07-29 16:39:55 +08:00
 bestehen

ss=re.findall(u'(\d+)小时前',s) 这里的 u 是表示匹配汉字吗?为啥有人说里面有汉字必须用 u 呢?

2133 次点击
所在节点    Python
5 条回复
lanpong
2018-07-29 16:55:21 +08:00
用的 py 版本是什么,py2 的话就是 Unicode 的问题,也就是中文编码
bestehen
2018-07-29 22:52:45 +08:00
@lanpong 我用其他编码就匹配不到汉字?
lanpong
2018-07-30 10:35:15 +08:00
@bestehen #2
你需要了解一下编码。http://wklken.me/posts/2013/08/31/python-extra-coding-intro.html
所以我还是推荐 Python3,不需要折腾这些问题
msg7086
2018-07-30 12:28:59 +08:00
u 决定了你字符串的编码方式,而不是匹配的内容。
也就是说,u 改变的是你的正则表达式,而不是 s 与正则表达式之间的关系。
0mza987
2018-08-01 21:13:56 +08:00
楼主需要了解下编码知识
http://pycoders-weekly-chinese.readthedocs.io/en/latest/issue5/unipain.html
看完这篇你就懂了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/475102

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX