我喜欢用这个表达
if 'MICHAEL89' in USERNAMES:
...
其中USERNAMES是一个列表。
是否有任何方法来匹配不区分大小写的项目,或者我需要使用自定义方法?只是想知道是否需要为此编写额外的代码。
我喜欢用这个表达
if 'MICHAEL89' in USERNAMES:
...
其中USERNAMES是一个列表。
是否有任何方法来匹配不区分大小写的项目,或者我需要使用自定义方法?只是想知道是否需要为此编写额外的代码。
当前回答
我会做一个包装,这样你就不会受到伤害了。最低限度,例如……:
class CaseInsensitively(object):
def __init__(self, s):
self.__s = s.lower()
def __hash__(self):
return hash(self.__s)
def __eq__(self, other):
# ensure proper comparison between instances of this class
try:
other = other.__s
except (TypeError, AttributeError):
try:
other = other.lower()
except:
pass
return self.__s == other
现在,如果caseinsensitive ('MICHAEL89')在whatever:应该按照要求行事(无论右边是列表、字典还是集合)。(它可能需要更多的努力来实现字符串包含的类似结果,避免在某些情况下涉及unicode的警告,等等)。
其他回答
你可以这样做
matcher = re.compile('MICHAEL89', re.IGNORECASE)
filter(matcher.match, USERNAMES)
更新:玩了一点,我认为你可以得到一个更好的短路类型的方法使用
matcher = re.compile('MICHAEL89', re.IGNORECASE)
if any( ifilter( matcher.match, USERNAMES ) ):
#your code here
filter函数来自itertools,它是Python中我最喜欢的模块之一。它比生成器快,但只在调用时创建列表的下一项。
我的5美分(错误的)
"".join([' a']).lower()
更新
哎呦,完全同意@jpp,我会把它作为一个糟糕做法的例子:(
Str.casefold建议用于不区分大小写的字符串匹配。@nmichaels的解决方案可以简单地进行调整。
使用:
if 'MICHAEL89'.casefold() in (name.casefold() for name in USERNAMES):
Or:
if 'MICHAEL89'.casefold() in map(str.casefold, USERNAMES):
根据文档:
大小写折叠类似于小写,但更激进,因为它 用于删除字符串中的所有大小写区别。例如, 德语小写字母“ß”相当于“ss”。因为它是 已经小写了,lower()不会对'ß'做任何事情;casefold () 将其转换为“ss”。
这里有一种方法:
if string1.lower() in string2.lower():
...
为此,string1和string2对象的类型都必须是string。
为了把它写在一行里,我是这样做的:
if any(([True if 'MICHAEL89' in username.upper() else False for username in USERNAMES])):
print('username exists in list')
不过我并没有在时间上进行测试。我不确定它有多快/有效率。