Ch 12 Solution: Dictionary Counters

23.7. Ch 12 Solution: Dictionary Counters#

Now it’s your turn to practice dictionary counters

  1. Copy the code from the demo that counts letters in a string. Modify the string to be something else and find the letter_counts (no need to sort)

# create a dictionary counter before the loop
# it has no entries, since we have seen no letters yet
letter_counts = {}

# go through each letter in the string
for letter in "your text here":
    if letter not in letter_counts: # If there is no entry for this letter yet 
        letter_counts[letter] = 1   # then make an entry set to 1
    else: # otherwise, there was an entry
        letter_counts[letter] += 1  # so add one to that entry

# we now have the total number of letters
display("total letter counts are:")
display(letter_counts)
'total letter counts are:'
{'y': 1, 'o': 1, 'u': 1, 'r': 2, ' ': 2, 't': 2, 'e': 3, 'x': 1, 'h': 1}

Now let’s try this with words.

The code below makes a string, and then splits it into words by dividing it apart at each space.

# Save a poem into a string (we can use """ to make a multiline string)
# Fire and Ice BY ROBERT FROST (now public domain)
poem = """Some say the world will end in fire,
Some say in ice.
From what I’ve tasted of desire
I hold with those who favor fire.
But if it had to perish twice,
I think I know enough of hate
To say that for destruction ice
Is also great
And would suffice."""

# split the string (all lowercase) into words
import re # import the Regular Expressions library, to help us split words

#make the poem all lowercase
lower_case_poem = poem.lower()

# split the poem into pieces at all spaces and newlines (\s), and ,'s and .'s
poem_split_by_spaces_and_punctuation = re.split(("[\s,.]"), lower_case_poem)

# get rid of some empty strings "" that ended up in our list
split_poem = list(filter(None, poem_split_by_spaces_and_punctuation))

print(split_poem)
['some', 'say', 'the', 'world', 'will', 'end', 'in', 'fire', 'some', 'say', 'in', 'ice', 'from', 'what', 'i’ve', 'tasted', 'of', 'desire', 'i', 'hold', 'with', 'those', 'who', 'favor', 'fire', 'but', 'if', 'it', 'had', 'to', 'perish', 'twice', 'i', 'think', 'i', 'know', 'enough', 'of', 'hate', 'to', 'say', 'that', 'for', 'destruction', 'ice', 'is', 'also', 'great', 'and', 'would', 'suffice']
<>:20: SyntaxWarning: invalid escape sequence '\s'
<>:20: SyntaxWarning: invalid escape sequence '\s'
C:\Users\kmthayer\AppData\Local\Temp\ipykernel_38440\735270539.py:20: SyntaxWarning: invalid escape sequence '\s'
  poem_split_by_spaces_and_punctuation = re.split(("[\s,.]"), lower_case_poem)
  1. Make code that counts how often each word appears in split_poem (it should be very similar to the code from problem 1 above, but you should have word_counts instead of letter_counts, and you should loop over words instead of letters)

# create a dictionary counter before the loop
# it has no entries, since we have seen no words yet
word_counts = {}

# go through each word in the list of words
for word in split_poem:
    if word not in word_counts: # If there is no entry for this word yet 
        word_counts[word] = 1   # then make an entry set to 1
    else: # otherwise, there was an entry
        word_counts[word] += 1  # so add one to that entry

# we now have the total number of words
display("total word counts are:")
display(word_counts)
'total word counts are:'
{'some': 2,
 'say': 3,
 'the': 1,
 'world': 1,
 'will': 1,
 'end': 1,
 'in': 2,
 'fire': 2,
 'ice': 2,
 'from': 1,
 'what': 1,
 'i’ve': 1,
 'tasted': 1,
 'of': 2,
 'desire': 1,
 'i': 3,
 'hold': 1,
 'with': 1,
 'those': 1,
 'who': 1,
 'favor': 1,
 'but': 1,
 'if': 1,
 'it': 1,
 'had': 1,
 'to': 2,
 'perish': 1,
 'twice': 1,
 'think': 1,
 'know': 1,
 'enough': 1,
 'hate': 1,
 'that': 1,
 'for': 1,
 'destruction': 1,
 'is': 1,
 'also': 1,
 'great': 1,
 'and': 1,
 'would': 1,
 'suffice': 1}