首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >验证字符串中是否存在所有字符序列(Python 2+)

验证字符串中是否存在所有字符序列(Python 2+)
EN

Stack Overflow用户
提问于 2016-07-27 11:08:39
回答 2查看 66关注 0票数 1

因此,要验证一个字符串是另一个字符串的子集,在python中,您可以使用set/frozensets类和issubset方法-仅适用于单个字符,也可以使用正则表达式,这基本上是从行首开始的多个先行断言。我想使用regex选项。

如果不像下面这样做(使用遍历字符串和手动创建先行断言,这可能会在我将处理的大数据的情况下生成一个巨大的字符串),有没有其他方法可以以更简洁/直接的方式构建这种先行?另一项是,我将不会只使用单个字符。因此,所需的先行断言的数量可能会变得非常大。

代码语言:javascript
复制
import re

userInput = raw_input()
listOfChars = 'asdfgei'

myRegexString = ''
for i in listOfChars:
    myRegexString = myRegexString+'(?=.*'+i+')'
    myRegexCompiled = re.compile(myRegexString)
if myRegexCompiled.(userInput):
    print True
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-07-27 11:21:25

如果要验证集合中的所有字符序列是否都出现在给定的字符串中,请使用带有生成器表达式的all()

代码语言:javascript
复制
answer = all(word in string for word in bag)
票数 3
EN

Stack Overflow用户

发布于 2016-07-27 11:20:52

假设您有两个字符串-- userInput,它可能非常大,而listOfChars,它相对较小。您希望检查userInput中是否存在listOfChars的每个元素,而不是将userInput转换为set

这不需要使用正则表达式--这样做会更快:

代码语言:javascript
复制
userInput = raw_input()
listOfChars = 'asdfgei'

def containsSubset(large, small):
   for element in set(small): # Convert to a set to remove dupes
       if not large.contains(element):
           return False
   return True

return containsSubset(userInput, listOfChars)

这将是O(M * N),其中M是userInput的大小,N是listOfChars的大小。

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

https://stackoverflow.com/questions/38603046

复制
相关文章

相似问题

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