Midterm projects aren't graded yet - will be soon.
Aside : fifty fizzbuzzes discussion | Jim's version
Discuss the homework. I've posted some examples.
This week : data structures (chap 11). Please read it.
Python "dictionary" data structure. Like an array, but with non-numeric "keys". The pairs of things in 'em are called (key, value) pairs. And there are lots of tricky methods built in.
jim = { "name" : "Jim", "age": 53 }
print("My name is ", jim['name'])
print("My age is ", jim['age']
# Look at dir(jim) to see all the methods like
# jim.keys()
# jim.items()
# jim.has_key(key)
# jim.get(key, value_otherwise)
Dictionaries are very useful data structures. In fact, the symbol table of a running program is essentially just a dictionary, with each variable's name and value. Objects are very like dictionaries, with "slots" for both data and methods. Most of the other CS data structures are things with specific uses built from lists and dictionaries.
(Discuss javascript objects and dictionaries ...)
Dictionaries are sometimes called "hash tables" or just "hashes" ... discuss why.
How are dictionaries and objects similar? Different?
The "name spaces" that we've been seeing, a list of variables and values that we keep track of when a function runs ... those are just essentially a dictionary.
Be clear that dictionaries are unordered ... what does that mean? Can we sort a dictionary?
One thing dictionaries are good for is counting things, using key:count for each sort of thing.
Example: counting how many times each word appears in a file.
The task is to write a program which will read in a file which has one word per line, and then to report how many times each word was seen.
A sample words.txt file is attached. Here's the start of the program :
"""
count_words.py
Read words.txt which has one word per line.
Count how many times each word appears
and print a summary.
$ python count_words.py
-- count_words --
12 cat
2 dog
2 duck
1 elephant
3 mouse
"""
def main():
print '-- count_words --'
if __name__ == '__main__':
import doctest
doctest.testmod()
main()
And here's the corresponding words.txt file like.
cat
dog
elephant
cat
cat
mouse
mouse
duck
mouse
duck
dog
Attached are the versions of these we worked on in class.
We now have these sorts of things which can store information :
These can be embedded within each other to create all sorts of containers for various kinds of information, depending on its internal structure.
Can you think of an example of
last modified | size | ||
count_words.py | Wed Jan 22 2025 04:55 am | 612B | |
words.txt | Wed Jan 22 2025 04:55 am | 71B |