我喜欢用这个表达

if 'MICHAEL89' in USERNAMES:
    ...

其中USERNAMES是一个列表。


是否有任何方法来匹配不区分大小写的项目,或者我需要使用自定义方法?只是想知道是否需要为此编写额外的代码。


当前回答

我的5美分(错误的)

"".join([' a']).lower()

更新

哎呦,完全同意@jpp,我会把它作为一个糟糕做法的例子:(

其他回答

这里有一种方法:

if string1.lower() in string2.lower(): 
    ...

为此,string1和string2对象的类型都必须是string。

username = 'MICHAEL89'
if username.upper() in (name.upper() for name in USERNAMES):
    ...

另外:

if username.upper() in map(str.upper, USERNAMES):
    ...

或者,是的,您可以创建一个自定义方法。

我的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 'MICHAEL89' in map(lambda name: name.upper(), USERNAMES):
   ...

在本例中,我们将形成一个新列表,其中USERNAMES中的所有条目都转换为大写,然后与这个新列表进行比较。

更新

正如@viraptor所说,使用生成器而不是map更好。请看@内森的回答。