鱼C论坛

 找回密码
 立即注册
查看: 62|回复: 1

[已解决]正则表达式使用“\w+", 为何不能全部字符都找到?

[复制链接]
发表于 2024-12-1 23:21:55 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x


import re

re.search(r'\w+','I want to go to swiming (我想去游泳!)')
            
<re.Match object; span=(0, 1), match='I'>

“\w+”是可以全部找到的, 为和只输出“I” ?
最佳答案
2024-12-1 23:27:07
在正则表达式中,`\w` 的含义是匹配字母、数字及下划线字符,相当于 `[a-zA-Z0-9_]`,因此它无法匹配空格、标点符号或者中文字符。在 `re.search()` 满足匹配条件时,它只会返回第一个匹配的结果。

在你的例子中,输入字符串是 `I want to go to swiming (我想去游泳!)`,由于 `\w+` 匹配第一个字母或数字开始的连续字符,所以只匹配到了 `I`。

如果希望匹配整个文本的多个部分,可以尝试使用 `re.findall()`:
import re

result = re.findall(r'\w+', 'I want to go to swiming (我想去游泳!)')
print(result)

`re.findall()` 将返回所有匹配的部分,这样可以得到字符串中符合条件的所有部分。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-12-1 23:27:07 | 显示全部楼层    本楼为最佳答案   
在正则表达式中,`\w` 的含义是匹配字母、数字及下划线字符,相当于 `[a-zA-Z0-9_]`,因此它无法匹配空格、标点符号或者中文字符。在 `re.search()` 满足匹配条件时,它只会返回第一个匹配的结果。

在你的例子中,输入字符串是 `I want to go to swiming (我想去游泳!)`,由于 `\w+` 匹配第一个字母或数字开始的连续字符,所以只匹配到了 `I`。

如果希望匹配整个文本的多个部分,可以尝试使用 `re.findall()`:
import re

result = re.findall(r'\w+', 'I want to go to swiming (我想去游泳!)')
print(result)

`re.findall()` 将返回所有匹配的部分,这样可以得到字符串中符合条件的所有部分。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-22 02:56

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表