2009-05-28 22 views

答えて

148

stringタイプはこれをサポートしていません。おそらくthe regular expression sub methodre.IGNORECASEオプションを付けておきましょう。

>>> 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' 
+7

re.subと(?i)フラグを使用して1回の置換を使用する方が効率的です:re.sub( '(?i) '+ re。エスケープ( 'hippo')、 'giraffe'、 '私は私の誕生日にhIPpoが必要です') –

+8

+1 for re.escape – daboross

+2

**文字列のみの** re.escape **なぜですか?ありがとう。 – Elena

61
import re 
pattern = re.compile("hello", re.IGNORECASE) 
pattern.sub("bye", "hello HeLLo HELLO") 
# 'bye bye bye' 
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):] 
+2

しかし、これは新しいものですべてのオカレンスを変更するのではなく、最初のオカレンスだけを変更します。 – rsmoorthy

+3

正規表現よりも読みにくいです。ここでホイールを再開発する必要はありません。 –

+0

これとupvotedバージョンとの性能比較を行うことは興味深いでしょう。あるいは、Pythonで解釈されているために時間がかかるかもしれません。 –

5

がbFlochの答えに引き続き必要とせず、この機能はありません1が、新しいと古いのすべての出現箇所を変更します - 大文字小文字を区別しない方法で。

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 
+0

非常にうまくいった。正規表現よりもはるかに優れています。すべての種類の文字を扱いますが、正規表現は英数字以外のものについては非常に難解です。好ましい回答IMHO。 – fyngyrz

+0

あなたがしなければならないことは、正規表現をエスケープすることです:受け入れられた答えはこれよりもはるかに短くて読みやすくなります。 –

-1

は前に答えを掲載しませんし、このスレッドは本当に古いですが、私は別のsollutionを思い付いたし、それにappearant欠点があるので、もし私があなたのRESPONSを得ることができる、ImはPythonプログラミングで味付けない考え出し、ポイントしてください

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' 

また、オプションの "フラグ" を使用し、引数:その良い学習:)

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)) 
+2

学習のため:一般的に、文字列を検索して置換するときは、最初に配列に変換する必要はありません。だから、最初の答えはおそらく最高です。それは外部モジュールを使用している間、文字列を1つの文字列として扱います。このプロセスで何が起きているのかがさらにはっきりしています。 – isaaclw

25

は非常にシンプルな、単一のラインで以来、そのうち

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' 
1

Like Blair Conradは、string.replaceはこれをサポートしていないと言います。

正規表現re.subを使用しますが、最初に置換文字列をエスケープしてください。 2.6ではre.subのflagsオプションはないので、組み込み修飾子'(?i)'(またはREオブジェクト、Blair Conradの答えを参照)を使用する必要があります。また、もう一つの落とし穴は、文字列が与えられた場合、substは置換テキストのバックスラッシュエスケープを処理することです。これを避けるために、代わりにラムダを渡すことができます。ここで

機能です:

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' 
0

私は(少しスクロールダウン)escape sequencesに変換され、\ tを持っていたので、私はre.sub変換エスケープシーケンスをするためにエスケープ文字をバックスラッシュと指摘しました。

は、私は次のように書いたことないようにするには:

は大文字と小文字を区別を交換してください。

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

、あなたはそれがbashslash文字がちょうどあなたの検索をデコードし、または文字列を置き換え、エスケープシーケンスに変換特別な意味を取得している、ここで他の回答のように、エスケープ文字に置き換えたい場合。 Pythonの3では、.decode( "unicode_escape")のような何かをする必要がある場合があります#1のpython3のPython 2.7.8で

をテスト済み

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

お役に立てば幸いです。