不区分大小写的替换

时间:2009-05-28 03:35:25

标签: python string case-insensitive

在Python中进行不区分大小写的字符串替换的最简单方法是什么?

10 个答案:

答案 0 :(得分:191)

string类型不支持此功能。您可能最好使用the regular expression sub method选项{/ 3}}。

>>> import re
>>> insensitive_hippo = re.compile(re.escape('hippo'), re.IGNORECASE)
>>> insensitive_hippo.sub('giraffe', 'I want a hIPpo for my birthday')
'I want a giraffe for my birthday'

答案 1 :(得分:70)

import re
pattern = re.compile("hello", re.IGNORECASE)
pattern.sub("bye", "hello HeLLo HELLO")
# 'bye bye bye'

答案 2 :(得分:35)

单行:

import re
re.sub("(?i)hello","bye", "hello HeLLo HELLO") #'bye bye bye'
re.sub("(?i)he\.llo","bye", "he.llo He.LLo HE.LLO") #'bye bye bye'

或者,使用可选的“flags”参数:

import re
re.sub("hello", "bye", "hello HeLLo HELLO", flags=re.I) #'bye bye bye'
re.sub("he\.llo", "bye", "he.llo He.LLo HE.LLO", flags=re.I) #'bye bye bye'

答案 3 :(得分:10)

继续bFloch的回答,这个函数不会改变一个,而是所有出现旧的new - 以不区分大小写的方式。

def ireplace(old, new, text):
    idx = 0
    while idx < len(text):
        index_l = text.lower().find(old.lower(), idx)
        if index_l == -1:
            return text
        text = text[:index_l] + new + text[index_l + len(old):]
        idx = index_l + len(new) 
    return text

答案 4 :(得分:4)

关于语法细节和选项的有趣观察:

在Win32上使用Python 3.7.2(tags / v3.7.2:9a3ffc0492,2018年12月23日,23:09:28)[MSC v.1916 64位(AMD64)]

import re
old = "TREEROOT treeroot TREerOot"
re.sub(r'(?i)treeroot', 'grassroot', old)

'草根草根草根'

re.sub(r'treeroot', 'grassroot', old)

'TREEROOT草根TREerOot'

re.sub(r'treeroot', 'grassroot', old, flags=re.I)

'草根草根草根'

re.sub(r'treeroot', 'grassroot', old, re.I)

'TREEROOT草根TREerOot'

因此,匹配表达式中的(?i)前缀或添加“ flags = re.I”作为第四个参数将导致不区分大小写的匹配。 但是,仅使用“ re.I”作为第四个参数不会导致不区分大小写的匹配。

为进行比较,

re.findall(r'treeroot', old, re.I)

['TREEROOT','treeroot','TREerOot']

re.findall(r'treeroot', old)

['treeroot']

答案 5 :(得分:2)

这不需要RegularExp

def ireplace(old, new, text):
    """ 
    Replace case insensitive
    Raises ValueError if string not found
    """
    index_l = text.lower().index(old.lower())
    return text[:index_l] + new + text[index_l + len(old):] 

答案 6 :(得分:2)

就像Blair Conrad说的那样string.replace不支持这个。

使用正则表达式re.sub,但请记住首先转义替换字符串。请注意,re.sub在2.6中没有标记选项,因此您必须使用嵌入修饰符'(?i)'(或RE对象,请参阅Blair Conrad的答案)。另外,另一个缺陷是如果给出了字符串,sub将在替换文本中处理反斜杠转义。为了避免这种情况,可以改为传入lambda。

这是一个功能:

import re
def ireplace(old, repl, text):
    return re.sub('(?i)'+re.escape(old), lambda m: repl, text)

>>> ireplace('hippo?', 'giraffe!?', 'You want a hiPPO?')
'You want a giraffe!?'
>>> ireplace(r'[binfolder]', r'C:\Temp\bin', r'[BinFolder]\test.exe')
'C:\\Temp\\bin\\test.exe'

答案 7 :(得分:1)

此函数同时使用str.replace()re.findall()函数。 它将以不区分大小写的方式用pattern替换stringrepl中所有def replace_all(pattern, repl, string) -> str: occurences = re.findall(pattern, string, re.IGNORECASE) for occurence in occurences: string = string.replace(occurence, repl) return string 的出现。

{{1}}

答案 8 :(得分:0)

之前从未发过一个答案而且这个帖子真的很老但是我想出了另一个解决方案并且认为我可以得到你的回应,我没有在Python编程中经验丰富,所以如果有它的外观缺点,请指出它们,因为它的好学习:))

i='I want a hIPpo for my birthday'
key='hippo'
swp='giraffe'

o=(i.lower().split(key))
c=0
p=0
for w in o:
    o[c]=i[p:p+len(w)]
    p=p+len(key+w)
    c+=1
print(swp.join(o))

答案 9 :(得分:0)

我没有被转换为escape sequences(向下滚动),所以我注意到re.sub将反向转义的转义字符转换为转义序列。

为了防止我写下以下内容:

替换不区分大小写。

import re
    def ireplace(findtxt, replacetxt, data):
        return replacetxt.join(  re.compile(findtxt, flags=re.I).split(data)  )

另外,如果你想用转义字符替换它,就像这里得到特殊含义的bashslash字符转换为转义序列的其他答案一样,只需解码你的find,或者替换字符串。在Python 3中,可能需要执行类似.decode(&#34; unicode_escape&#34;)#python3

findtxt = findtxt.decode('string_escape') # python2
replacetxt = replacetxt.decode('string_escape') # python2
data = ireplace(findtxt, replacetxt, data)

在Python 2.7.8中测试

希望有所帮助。