我正在尝试使用以下代码,它应该从用户输入的文本字符串中删除元音。
def isVowel(text):
if text in ("a", "e", "i", "o", "u", "A", "E", "I", "O", "U"):
return True
def withoutVowels(text):
for char in text:
if(isVowel == True):
text = text.replace(char, "")
return text
isVowel函数工作正常,但是当我使用它时它似乎没有正确评估,为什么会这样?
答案 0 :(得分:11)
if (isVowel == True):
应该是
if isVowel(char):
isVowel
是一个函数对象。 isVowel == True
永远是假的。
请注意,您也可以使用str.translate更快,更简单地执行此操作。
In [90]: 'Abracadabra'.translate(None, 'aeiouAEIOU')
Out[90]: 'brcdbr'
或,(如EOL所指出的)使用正则表达式:
In [93]: import re
In [95]: re.sub(r'(?i)[aeiou]', '', 'Abracadabra')
Out[95]: 'brcdbr'
但是,str.translate
在这种情况下更快:
In [94]: %timeit 'Abracadabra'.translate(None, 'aeiouAEIOU')
1000000 loops, best of 3: 316 ns per loop
In [96]: %timeit re.sub(r'(?i)[aeiou]', '', 'Abracadabra')
100000 loops, best of 3: 2.26 us per loop
答案 1 :(得分:1)
你可以在一行中完成这项工作,因为Python非常棒:
def withoutVowels(text):
return "".join(c for c in text if c not in "aeiouAEIOU")