in
And not in
OperatorsYou can connect to Gradescope to take weekly graded quiz today during the last 15 minutes of the class.
Once you start the quiz you have 15 minutes to finish it.
You can only take this quiz today.
There is not makeup for the weekly quiz because Gradescope does not permit it.
I have posted a solution to homework 2 here.
Let's take a look.
I have posted homework 4 here.
It is due this coming Sunday at 11:59 PM.
Are there any questions before I begin?
print
statements>>> students = {} >>> students["09329034"] = ("Jane", "Adams","jadamsjadams@yahoo.com") >>> students["09929034"] = ("Alexander", "Smith","bigboy@hotmail.com") >>> students["05431692"] = ("Christopher", "Cannon","chris@nomail.com") >>> students["07511379"] = ("Joseph", "Malloney","jmaljoem@yahoo.com") >>> students["04175276"] = ("James", "Reynolds","jrjim.reynolds@gmail.com")
for
loop ...>>> for id in students: ... print(id, students[id]) ... 09329034 ('Jane', 'Adams', 'jadamsjadams@yahoo.com') 09929034 ('Alexander', 'Smith', 'bigboy@hotmail.com') 05431692 ('Christopher', 'Cannon', 'chris@nomail.com') 07511379 ('Joseph', 'Malloney', 'jmaljoem@yahoo.com) 04175276 ('James', 'Reynolds', 'jrjim.reynolds@gmail.com')
sorted
sorted
takes as an argument anything
that can be used in a for
loop ...
sorted
on a list of numbers
>>> nums = [5,8,2,6,1,9,3]
>>> sorted(nums) [1, 2, 3, 5, 6, 8, 9]
>>> sorted(students) ['04175276', '05431692', '07511379', '09329034', '09929034']
sorted
in a for
loop over
a dictionary
>>> for id in sorted(students): ... print(id, students[id]) ... 04175276 ('James', 'Reynolds', 'jrjim.reynolds@gmail.com') 05431692 ('Christopher', 'Cannon', 'chris@nomail.com') 07511379 ('Joseph', 'Malloney', 'jmaljoem@yahoo.co') 09329034 ('Jane', 'Adams', 'jadamsjadams@yahoo.com') 09929034 ('Alexander', 'Smith', 'bigboy@hotmail.com')
sorted
on a dictionary to create a sorted list
of keys
>>> sorted_ids = sorted(students) >>> sorted_ids ['04175276', '05431692', '07511379', '09329034', '09929034']
>>> sorted_ids.reverse() >>> sorted_ids ['09929034', '09329034', '07511379', '05431692', '04175276']
>>> for id in sorted_ids: ... print(id, students[id]) ... 09929034 ('Alexander', 'Smith', 'bigboy@hotmail.com') 09329034 ('Jane', 'Adams', 'jadamsjadams@yahoo.com') 07511379 ('Joseph', 'Malloney', 'jmaljoem@yahoo.com') 05431692 ('Christopher', 'Cannon', 'chris@nomail.com') 04175276 ('James', 'Reynolds', 'jrjim.reynolds@gmail.com')
in
And not in
Operatorsin
operator
>>> numbers [1, 2, 3, 4, 5] >>> 5 in numbers True >>> 6 in numbers False
not in
operator tells us whether a value is
not found in a list
>>> 5 not in numbers False >>> 6 not in numbers True
not
and in
together make a single
operator
>>> words_integers {'three': 3, 'five': 5, 'two': 2, 'one': 1, 'four': 4} >>> "three" in words_integers True >>> 3 in words_integers False
del
statement
del DICTIONARY_NAME[KEY]
where DICTIONARY_NAME is a variable that points
to the dictionary object
>>> words_integers {'three': 3, 'five': 5, 'two': 2, 'one': 1, 'four': 4} >>> del words_integers["five"] >>> words_integers {'three': 3, 'two': 2, 'one': 1, 'four': 4}
del words_integers["six"]
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
KeyError: 'six'
len
function can be used with a dictionary>>> email_addresses {'Chris': 'chrisk@yahoo.com', 'Alan': 'alanh@gmail.com'} >>> len(email_addresses) 2 >>> words_integers {'five': 5, 'one': 1, 'six': 6, 'two': 2, 'four': 4, 'three': 3} >>> len(words_integers) 6
bool
...
if
and while
statements both need
boolean expressions
and
or
not
value == 0 answer == "" num != 0
>>> value = "" >>> if value: ... print("True") ... else: ... print("False") ... False
>>> value = "x" >>> if value: ... print("True") ... else: ... print("False") ... True
>>> def true_or_false(value): ... if value: ... print("True") ... else: ... print("False") ...
>>> true_or_false(0) False >>> true_or_false(0.0) False
>>> true_or_false(1) True >>> true_or_false(4) True
>>> true_or_false(-1) True >>> true_or_false(-100) True
>>> file = open("students.txt", "r") >>> file <_io.TextIOWrapper name="students.txt" mode="r" encoding="UTF-8"> >>> true_or_false(file) True
None
None
points to nothingNone
is false
>>> true_or_false(None) False
>>> strings_integers = {"one":1, "two":2, "three":3} >>> strings_integers["three"] 3 >>> integers_strings = {1:"one", 2:"two", 3:"three"} >>> integers_strings[3] "three" >>> floats_strings = {1.0:"one", 2.0:"two", 3.0:"three"} >>> floats_strings[3.0] "three" >>> tuples_integers = {(1,1):1, (2,2):2, (3,3):3} >>> tuples_integers[(3,3)] 3 >>>
>>> lists_integers = {[1,1]:1, [2,2]:2, [3,3]:3}
Traceback (most recent call last):
File <stdin>, line 1, in <module>
TypeError: unhashable type: "list"
>>> jumble = {1:1, 2:2.0, 3:"three", 4:(4,4), 5:[5]} >>> for key in jumble: ... print(jumble[key]) ... 1 2.0 three (4, 4) [5]
>>> jumble_2 = {1:1, 2.0:2, "3":3} >>> for key in jumble_2: ... print(jumble_2[key]) ... 1 2 3
Method | Description |
---|---|
clear() | Clears the contents of a dictionary. |
get(key) | Gets the value associated with a specified key. If the key is not found, the method does not raise an exception. Instead, it returns a default value. |
pop(key) | Returns the value associated with a specified key and removes that key-value pair from the dictionary. If the key is not found, the method returns a default value. |
popitem() | Returns a randomly selected key-value pair as a tuple from the dictionary and removes that key-value pair from the dictionary. |
items() | Returns all the keys in a dictionary and their associated values. |
keys() | Returns all the keys in a dictionary. |
values() | Returns all the values in the dictionary. |
clear
method removes all entries from a directory>>> quiz_scores {"Mary Jones": [98, 95, 93, 92], "Tim Tyler": [88, 81, 79, 85], "John Smith": [100, 90, 85]}
>>> quiz_scores.clear() >>> quiz_scores {}
>>> quiz_scores = {}
id
function
>>> quiz_scores {"John Smith": [100, 90, 85], "Tim Tyler": [88, 81, 79], "Mary Jones": [98, 95, 93]} >>> id(quiz_scores) 139691305684744
>>> quiz_scores.clear() >>> id(quiz_scores) 140083427949384 >>> quiz_scores {}
quiz_scores = {}
id
on
quiz_scores
>>> id(quiz_scores) 140083428105992
>>> scores = quiz_scores["Mary Jones"] >>> scores [98, 95, 93]
>>> scores = quiz_scores["Mary Jonez"]
Traceback (most recent call last):
File <stdin>, line 1, in <module>
KeyError: "Mary Jonez"
>>> scores = quiz_scores.get("Mary Jones") >>> scores [98, 95, 93]
None
>>> scores = quiz_scores.get("Mary Jonez") >>> print(scores) None
if
statementfor
loop there would be no reason to
use get
>>> for key in quiz_scores: ... print(key, ":", quiz_scores[key]) ... Tim Tyler : [88, 81, 79] Mary Jones : [98, 95, 93] John Smith : [100, 90, 85]
>>> def get_score(key): ... score = quiz_scores.get(key) ... if score: ... return score ... else: ... print(key, "is not a valid key") ... >>>
>>> get_score("Mary Jones") [98, 95, 93]
>>> get_score("Mary Jonez") Mary Jonez is not a valid key
>>> quiz_scores {"Mary Jones": [98, 95, 93], "Tim Tyler": [88, 81, 79], "John Smith": [100, 90, 85]} >>> quiz_scores.pop("Mary Jones") [98, 95, 93] >>> quiz_scores {"Tim Tyler": [88, 81, 79], "John Smith": [100, 90, 85]}
>>> quiz_scores {"Tim Tyler": [88, 81, 79], "John Smith": [100, 90, 85]} >>> quiz_scores.popitem() ("Tim Tyler", [88, 81, 79])
>>> quiz_scores {"John Smith": [100, 90, 85]}
>>> names_usernames {"Mary Jones": "mjones", "John Smith": "wombat", "Tim Tyler": "ttyler"} >>> items = names_usernames.items() >>> items [('Mary Jones', 'mjones'), ('John Smith', 'wombat'), ('Tim Tyler', 'ttyler')]
>>> names_usernames
{"Mary Jones": "mjones", "Tim Tyler": "ttyler", "John Smith": "wombat"}
>>> items = names_usernames.items()
>>> items
dict_items([("Mary Jones", "mjones"), ("Tim Tyler", "ttyler"), ("John Smith", "wombat")])
dict_items
?dict_items
are one member of a family of data types called
view objects
>>> items = names_usernames.items() >>> type(items) <type "list">
>>> names_usernames["Fred Farnsworth"] = "fredster" >>> names_usernames {"Fred Farnsworth": "fredster", "Mary Jones": "mjones", "John Smith": "wombat", "Tim Tyler": "ttyler"}
>>> items [("Mary Jones", "mjones"), ("John Smith", "wombat"), ("Tim Tyler", "ttyler")]
dict-items
view object will show the new
entry
>>> names_usernames {"Mary Jones": "mjones", "Tim Tyler": "ttyler", "John Smith": "wombat"} >>> names_usernames["Fred Farnsworth"] = "fredster" >>> items dict_items([("Mary Jones", "mjones"), ("Fred Farnsworth", "fredster"), ("Tim Tyler", "ttyler"), ("John Smith", "wombat")])
>>> listing[0]
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: "dict_items" object does not support indexing
for pair in items: ... print(pair) ... ("Mary Jones", "mjones") ("John Smith", "wombat") ("Tim Tyler", "ttyler") ("Fred Farnsworth", "fredster") >>> for pair in listing: ... print("key:", pair[0], "value", pair[1]) ... key: Mary Jones value mjones key: John Smith value wombat key: Tim Tyler value ttyler key: Fred Farnsworth value fredster
>>> names_usernames.keys() ["Fred Farnsworth", "Mary Jones", "John Smith", "Tim Tyler"]
>>> names_usernames.keys()
dict_keys(["Mary Jones", "John Smith", "Tim Tyler", "Fred Farnsworth"])
>>> names_usernames.values() ["fredster", "mjones", "wombat", "ttyler"]
dict_values
view object
>>> names_usernames.values()
dict_values(["mjones", "wombat", "ttyler", "fredster"])
<li class="flat"><a href="#collecting_testing_assignments">Collecting and Testing Assignments</a></li> <li class="flat"><a href="#notifying_missing_work">Notifying You About Missing Work</a></li> <li class="flat"><a href="#late_work">Late Work</a>
"collecting_testing_assignments": "Collecting and Testing Assignments" "notifying_missing_work": "Notifying You About Missing Work" "late_work": "Late Work"
<h4 class="topic" id="collecting_testing_assignments">Collecting and Testing Assignments</h4> <h4 class="topic" id="notifying_missing_work">Notifying You About Missing Work</h4> <h4 class="topic" id="late_work">Late Work</h4>
"collecting_testing_assignments": "Collecting and Testing Assignments" "notifying_missing_work": "Notifying You About Missing Work" "late_work": "Late Work"