Jaki jest najprostszy sposób na zastąpienie łańcucha znaków niewrażliwym na wielkość liter w Pythonie?Nieczułe na wielkość liter zamień na
Odpowiedz
Typ string
nie obsługuje tego. Najlepiej najlepiej użyć opcji the regular expression sub method z opcją re.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'
import re
pattern = re.compile("hello", re.IGNORECASE)
pattern.sub("bye", "hello HeLLo HELLO")
# 'bye bye bye'
nie wymaga 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):]
Dobrze, ale to nie zmienia wszystkich wystąpień starego z nowym, ale tylko pierwszym wystąpieniem. – rsmoorthy
Jest mniej czytelny niż wersja regex. Nie trzeba tu wymyślać na nowo. –
Interesujące byłoby porównanie wydajności tej wersji z wersją przestawioną, która może być szybsza, co ma znaczenie w przypadku niektórych aplikacji. Lub może być wolniejszy, ponieważ działa więcej w interpretacji Pythona. –
Kontynuując odpowiedź bFloch użytkownika, funkcja ta zmiana nie jeden, ale wszystkie wystąpienia stare z nowym - w przypadku, niewrażliwego mody.
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
Bardzo dobrze zrobione. Znacznie lepiej niż regex; obsługuje wszystkie rodzaje znaków, podczas gdy regex jest bardzo wybredny w stosunku do wszystkiego, co nie jest alfanumeryczne. Preferowana odpowiedź IMHO. – fyngyrz
Wszystko, co musisz zrobić, to uciec przed regexem: zaakceptowana odpowiedź jest znacznie krótsza i łatwiejsza do odczytania niż ta. –
nigdy pisał odpowiedź przed i ten wątek jest bardzo stary, ale wpadłem na inny sollution i zorientowali mogę uzyskać respons, nie jestem zaprawiony w programowaniu Pythona, więc jeśli istnieją appearant wad do niego, proszę wskazać je od jego dobrej nauki :)
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))
Dla uczenia się: ogólnie rzecz biorąc, kiedy szukasz i zamieniasz na łańcuch, lepiej nie zamieniać go najpierw w tablicę. Dlatego pierwsza odpowiedź jest prawdopodobnie najlepsza. Podczas używania zewnętrznego modułu traktuje ciąg jako jeden ciąg. Trochę jaśniej, co się dzieje w tym procesie. – isaaclw
bardzo prosty, w jednej linii:
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'
Lub użyć opcjonalnego "flagi" Argument:
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'
Podobnie jak Blair Conrad mówi, że string.replace nie obsługuje tego.
Użyj wyrażeń regularnych re.sub
, ale pamiętaj, aby najpierw uciec przed zastępczym ciągiem znaków. Zauważ, że nie ma opcji flag w 2.6 dla re.sub
, więc będziesz musiał użyć wbudowanego modyfikatora '(?i)'
(lub obiektu RE, patrz odpowiedź Blair Conrad). Inną pułapką jest to, że sub przetwarza odwrotne ukośniki w tekście zastępczym, jeśli podany jest łańcuch. Aby tego uniknąć, można zamiast tego przekazać lambdę.
Poniżej funkcję:
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'
miałem \ t jest przekształcany do escape sequences (przewijania nieco w dół), więc zauważyć, że re.sub przekształca odwrotnym ukośnikiem uciec znaków sekwencje.
Aby zapobiec że napisałem co następuje:
Wymień wielkość liter ma znaczenie.
import re
def ireplace(findtxt, replacetxt, data):
return replacetxt.join( re.compile(findtxt, flags=re.I).split(data) )
Ponadto, jeśli chcesz go zastąpić znaków ewakuacyjnych, podobnie jak innych odpowiedzi tutaj, że są coraz szczególne znaczenie znaków bashslash konwertowane na sekwencje, po prostu zdekodować swoje znalezisko i lub wymienić łańcuch. W Pythonie 3, może zrobić coś podobnego .decode ("unicode_escape") # python3
findtxt = findtxt.decode('string_escape') # python2
replacetxt = replacetxt.decode('string_escape') # python2
data = ireplace(findtxt, replacetxt, data)
przetestowany w Pythonie 2.7.8
nadzieję, że pomoże.
- 1. Nieczułe na wielkość liter porównywanie ciągów znaków
- 2. JavaScript: niewrażliwe na wielkość liter
- 3. Lista niewrażliwa na wielkość liter
- 4. Nieczułe na kolumny kolumn w SQLAlchemy?
- 5. Wyszukiwanie niewrażliwe na wielkość liter w Mongo
- 6. Adresy niewrażliwe na wielkość liter dla Django?
- 7. Lista zapytań Django nieodczułowa na wielkość liter
- 8. Uruchamianie kwerendy niewrażliwe na wielkość liter
- 9. Wybrane opcje niewrażliwe na wielkość liter
- 10. wielkość liter na Mac dla file_exists()?
- 11. Jak ustawić operator% like% na wielkość liter?
- 12. Przełącznik niewrażliwy na wielkość liter jako zmienna?
- 13. Łańcuch niewrażliwy na wielkość liter :: znajdź
- 14. Czy mysql jest wrażliwy na wielkość liter?
- 15. Niewrażliwe na wielkość liter JFlex regex
- 16. Globalnie niewrażliwy na wielkość liter zsh/bash
- 17. Wykonywanie wyszukiwania niewrażliwego na wielkość liter
- 18. Jak mogę zrobić rozróżnianie wielkości liter niewrażliwe na wielkość liter?
- 19. Wyszukiwanie niewrażliwe na wielkość liter MySQL na polu varbinary?
- 20. wielkość liter Directory.Exists/File.Exists
- 21. PHP wielkość liter explode()
- 22. niewrażliwość na wielkość regex
- 23. Wybierz wielkość liter w LINQ
- 24. Jak mogę uzyskać Browser.text.include? być niewrażliwe na wielkość liter?
- 25. Filtr niewrażliwy na wielkość liter Spark'a SQL dla warunków kolumnowych
- 26. LINQ do grupy niewrażliwych na wielkość liter DataSet:
- 27. Analizator składni niewrażliwy na wielkość liter w C#
- 28. Railsy validates_uniqueness_of w wielu kolumnach z niewrażliwością na wielkość liter
- 29. Alfanumeryczne sortowanie wrażliwe na wielkość liter w postgresie
- 30. Jaka jest najbardziej efektywna niewrażliwa na wielkość liter grep?
Jeśli robisz tylko jedną zamianę lub chcesz zapisać wiersze kodu, bardziej efektywne jest użycie pojedynczego zastępowania za pomocą opcji re.sub i flagi (? I): re.sub ('(? I) "+ re.uciec ("hipopotam"), "żyrafa", "Chcę hIPpo na moje urodziny") –
+1 za re .escape – daboross
Dlaczego ** re.escape ** tylko dla ciągu liter? Dzięki. – Elena