首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用regex查找“hello”、“man”和“in”/?user=hello&user=man和user=‘

使用regex查找“hello”、“man”和“in”/?user=hello&user=man和user=‘
EN

Stack Overflow用户
提问于 2012-09-29 14:21:52
回答 3查看 89关注 0票数 2

我想在'user='之后从字符串'/?user=hello&user=man&user='中提取任何字符串。在这种情况下,我会得到'hello''man'''

,我被困在这里:

代码语言:javascript
复制
>>> import re

>>> s = '/?user=hello&user=man&user='
>>> re.findall("user=(.*)",s)
['hello&user=man&user=']

如果user=的最后一次出现也以&结束,我将能够找到我想要的东西,但是有人知道如何在这个字符串中找到['hello', 'man', '']吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-09-29 14:26:08

我将删除re并使用用于此目的的工具:

代码语言:javascript
复制
from urlparse import urlsplit, parse_qs

s = '/?user=hello&user=man&user='
parse_qs(urlsplit(s).query, keep_blank_values=True)
{'user': ['hello', 'man', '']}
票数 11
EN

Stack Overflow用户

发布于 2012-09-29 14:25:34

尝试以下几点:

代码语言:javascript
复制
>>> s = '/?user=hello&user=man&user='
>>> re.findall(r"user=([^&]*)", s)
['hello', 'man', '']
票数 3
EN

Stack Overflow用户

发布于 2012-09-29 14:26:24

是的,您需要做一个不是“贪婪”的正则表达式,并将最后一个user=作为您正在测试的(.*)的出现。让它更具体一些,user=(.*)?user=(.*)?user=(.*)将只匹配数据的第一次出现,而不是每个字符的巨大块。这就是为什么?操作符用正则表达式。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12653503

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档