Welcome to the Treehouse Community

Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.

Looking to learn something new?

Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.

Start your free trial

Python Python Collections (2016, retired 2019) Lists Disemvowel

Hussein Amr
Hussein Amr
2,461 Points

why is my code not working

def disemvowel(word):
    vowels = ['a','e','i','o','u','A','E','I','O','U']
    for letter in vowels:
        if letter in word:
            word.remove(letter)
        else:
            continue

    return word
disemvowel.py
def disemvowel(word):
    vowels = ['a','e','i','o','u','A','E','I','O','U']
    for letter in vowels:
        if letter in word:
            word.remove(letter)
        else:
            continue

    return word
Eric Boxer
Eric Boxer
9,026 Points

The argument word is a string, and strings have a method of remove. Try using replace instead.

3 Answers

Chris Freeman
MOD
Chris Freeman
Treehouse Moderator 68,460 Points

Remember the word argument is a string. To break word up into a list use list(word). This can be reassign back to word:

word = list(word)

Loop over the new extracted letters now in word:

for letter in word[:]:

The extra [:] means the for loop should iterate on a copy of word. A copy keeps the index references safe from deletions of letters from original extract word.

Now, if letter is in vowels it can be remove from word using word.remove(letter)

When the for loop completes, rejoin the letters of word back into a string. Use the join() method for this:

    return "".join(word)

Good Luck!!

Hussein Amr
Hussein Amr
2,461 Points

thanks man i got it now :D

Chris Freeman
MOD
Chris Freeman
Treehouse Moderator 68,460 Points

Your current approach will only find the first occurrence of each vowel in the word. Try reversing the comparison: check if each letter in the word is in the vowels list.

Post back if you need more hints. Good Luck!!

Hussein Amr
Hussein Amr
2,461 Points

still not working :/ i tried your method but maybe i did something wrong, I just flipped "vowels" and "word"

Chris Freeman
Chris Freeman
Treehouse Moderator 68,460 Points

Be careful not to modify the for loop iterable. If you're using word, then modifying word will throw off the indexes using by the for loop. Instead, use a copy of word by adding slice copy notation: word[:]

Repost your code if you're still stuck! Keep at it!

Chris Freeman
Chris Freeman
Treehouse Moderator 68,460 Points

Also, remember to convert the word in to a mutable list where letters can be removed. You can't remove letters from a string.

Hussein Amr
Hussein Amr
2,461 Points

Chris Freeman man i tried everything and im still stuck, also i don't know how to convert a word into a mutable

def disemvowel(word):
    word[:]
    vowels = ['a','e','i','o','u','A','E','I','O','U']
    for letter in vowels:
        if letter in word:
            word.remove(letter)
    return word