1. 程式人生 > >python學習內容.05

python學習內容.05

循環輸出 字符串 是否 功能 數據類型 匹配 選中 str AR

本節主要內容:
1. 字典的簡單介紹 2. 字典增刪改查和其他操作 3. 字典的嵌套
一. 字典的簡單介紹 字典(dict)是python中唯一的一個映射類型.他是以{ }括起來的鍵值對組成. 在dict中key是唯一的. 在保存的時候, 根據key來計 算出一個內存地址. 然後將key-value保存在這個地址中. 這種算法被稱為hash算法, 所以, 切記, 在dict中存儲的key-value中的 key‘必須是可hash的, 如果你搞不懂什麽是可哈希, 暫時可以這樣記, 可以改變的都是不可哈希的, 那麽可哈希就意味著不可變. 這個是為了能準確的計算內存地址而規定的.
已知的可哈希(不可變)的數據類型: int, str, tuple, bool 不可哈希(可變)的數據類型: list, dict, set
語法 : {key1: value1, key2: value2....}
註意: key必須是不可變(可哈希)的. value沒有要求.可以保存任意類型的數據
# 合法 dic = {123: 456, True: 999, "id": 1, "name": ‘sylar‘, "age": 18, "stu": [‘帥哥‘, ‘美女‘], (1, 2, 3): ‘麻花藤‘} print(dic[123]) print(dic[True]) print(dic[‘id‘]) print(dic[‘stu‘]) print(dic[(1, 2, 3)]) # 不合法 # dic = {[1, 2, 3]: ‘周傑倫‘} # list是可變的. 不能作為key # dic = {{1: 2}: "哈哈哈"} # dict是可變的. 不能作為key dic = {{1, 2, 3}: ‘呵呵呵‘} # set是可變的, 不能作為key
dict保存的數據不是按照我們添加進去的順序保存的. 是按照hash表的順序保存的. 而hash表不是連續的. 所以不能進行切片工作. 它只能通過key來獲取dict中的數據
二. 字典的增刪改查和其他相關操作
1. 增加
dic = {} dic[‘name‘] = ‘周潤發‘ # 如果dict中沒有出現這個key, 就會新增一個key-value的組合進dict dic[‘age‘] = 18 print(dic)
# 如果dict中沒有出現過這個key-value. 可以通過setdefault設置默認值 dic.setdefault(‘李嘉誠‘) # 也可以往裏面設置值. dic.setdefault("李嘉誠", "房地產") # 如果dict中已經存在了. 那麽setdefault將不會起作用
print(dic)
2. 刪除
ret = dic.pop("jay") print(ret)
del dic["jay"] print(dic)
# 隨機刪除. ret = dic.popitem()
# 清空字典中的所有內容 dic.clear()
3. 修改
dic = {"id": 123, "name": ‘sylar‘, "age": 18} dic1 = {"id": 456, "name": "麻花藤", "ok": "wtf"} dic.update(dic1) # 把dic1中的內容更新到dic中. 如果key重名. 則修改替換. 如果不存在key, 則新增. print(dic) print(dic1)
4. 查詢
查詢一般用key來查找具體的數據.
print(dic[‘name‘]) # print(dic[‘sylar‘]) # 報錯 print(dic.get("ok")) print(dic.get("sylar")) # None print(dic.get("sylar", "牛B")) # 牛B
5. 其他相關操作

dic = {"id": 123, "name": ‘sylar‘, "age": 18, "ok": "科比"}
print(dic.keys()) # dict_keys([‘id‘, ‘name‘, ‘age‘, ‘ok‘]) 不用管它是什麽.當成list來用就行 for key in dic.keys(): print(key)
print(dic.values()) # dict_values([123, ‘sylar‘, 18, ‘科比‘]) 一樣. 也當list來用 for value in dic.values(): print(value)
print(dic.items()) # dict_items([(‘id‘, 123), (‘name‘, ‘sylar‘), (‘age‘, 18), (‘ok‘, ‘科比‘)]) 這個東西也是list. 只不過list中裝的是tuple for key, value in dic.items(): # ?? 這個是解構 print(key, value)
# 解構 a, b = 1, 2 print(a, b)
(c, d) = 3, 4 print(c, d)
e, f = [1, 2, 3] # 解構的時候註意數量必須匹配 print(e, f)
三. 字典的嵌套 # 字典的嵌套 dic1 = { "name": "汪峰", "age": 18, "wife": { "name": ‘章子怡‘, "age": 28 }, "children": [‘第一個毛孩子‘, ‘第二個毛孩子‘], "desc": ‘峰哥不會告我吧. 沒關系. 我想上頭條的‘ }
print(dic1.get("wife").get("name")) print(dic1.get("children")) print(dic1.get("children")[1])
練習: dic1 = { ‘name‘:[‘alex‘,2,3,5], ‘job‘:‘teacher‘, ‘oldboy‘:{‘alex‘:[‘python1‘,‘python2‘,100]} } 1,將name對應的列表追加一個元素’wusir’。 2,將name對應的列表中的alex首字母大寫。 3,oldboy對應的字典加一個鍵值對’老男孩’,’linux’。 4,將oldboy對應的字典中的alex對應的列表中的python2刪除

作業:

,有如下變量(tu是個元祖),請實現要求的功能
tu = ("alex", [11, 22, {"k1": ‘v1‘, "k2": ["age", "name"], "k3": (11, 22, 33)}, 44])
a.講述元祖的特性;;答:元祖用()表示,是只讀列表,可以索引切片,循環,叠代,但是不能刪改.
b.請問tu變量中的第一個元素"alex"是否可被修改 答:不可以被修改
c.請問tu變量中的"k2"對應的值是什麽類型?是否可以被修改?如果可以,請在其中添加一個元素"Seven"
‘‘‘k2對應的值是列表型數據,可以改變.‘‘‘
tu[1][2]["k2"]=["age","name","Seven"]
print(tu)
d.請問tu變量中的"k3"對應的值是什麽類型?是否可以被修改?如果可以,請在其中添加一個元素"Seven"
‘‘‘k3對應的值是元祖,不可以修改‘‘‘
2, 字典dic, dic = {‘k1‘: "v1", "k2": "v2", "k3": [11, 22, 33]}

a.請循環輸出所有的key
print(dic.keys())
b.請循環輸出所有的value
print(dic.values())
c.請循環輸出所有的key和value
for a in dic.keys():
print(a)
print(dic.get(a))
d.請在字典中添加一個鍵值對,"k4": "v4",輸出添加後的字典
dic["k4"]="v4"
print(dic)
e.請在修改字典中"k1"對應的值為"alex",輸出修改後的字典
dic["k1"]="alex"
print(dic)
f.請在k3對應的值中追加一個元素44,輸出修改後的字典
dic["k3"]=[11, 22, 33,44]
print(dic)
g.請在k3對應的值的第1個位置插入個元素18,輸出修改後的字典
dic["k3"]=[11,18, 22, 33,]
print(dic)
3,av_catalog = {
"歐美": {
"www.youporn.com": ["很多免費的,世界最大的", "質量一般"],
"www.pornhub.com": ["很多免費的,也很大", "質量比yourporn高點"],
"letmedothistoyou.com": ["多是自拍,高質量圖片很多", "資源不多,更新慢"],
"x-art.com": ["質量很高,真的很高", "全部收費,屌絲請繞過"]
},
"日韓": {
"tokyo-hot": ["質量怎樣不清楚,個人已經不喜歡日韓範了", "verygood"]
},
"大陸": {
"1024": ["全部免費,真好,好人一生平安", "服務器在國外,慢"]
}
}

a, 給此["很多免費的,世界最大的", "質量一般"]列表第二個位置插入一個元素:‘量很大‘。
av_catalog["歐美"]["www.youporn.com"]="很多免費的,世界最大的", "質量一般","量很大"
print(av_catalog)
b, 將此["質量很高,真的很高", "全部收費,屌絲請繞過"]列表的"全部收費,屌絲請繞過"刪除。
av_catalog["歐美"]["x-art.com"]="質量很高,真的很高"
print(av_catalog)
c, 將此["質量很高,真的很高", "全部收費,屌絲請繞過"]列表的"全部收 費,屌絲請繞過"刪除。
av_catalog["歐美"]["x-art.com"]="質量很高,真的很高"
print(av_catalog)
d, 將此["質量怎樣不清楚,個人已經不喜歡日韓範了", "verygood"]列表的"verygood"全部變成大寫。
av_catalog["日韓"]["tokyo-hot"][1]=av_catalog["日韓"]["tokyo-hot"][1].upper()
print(av_catalog)
e, 給‘大陸‘對應的字典添加一個鍵值對‘1048‘: [‘一天就封了‘]
av_catalog["大陸"]["1048"]="一天就封了"
print(av_catalog)
f, 刪除此"letmedothistoyou.com": ["多是自拍,高質量圖片很多", "資源不多,更新慢"]鍵值對。
del av_catalog["歐美"]["letmedothistoyou.com"]
print(av_catalog)
g, 給此["全部免費,真好,好人一生平安", "服務器在國外,慢"]列表的第一個元素,加上一句話:‘可以爬下來‘
av_catalog["大陸"]["1024"][1]="服務器在國外,慢,可以爬下來"
print(av_catalog)
4、有字符串"k:1|k1:2|k2:3|k3:4"處理成字典{‘k‘: 1, ‘k1‘: 2....}
s=a.split("|")
dic={}
for s1 in s:
dic[s1.split(":")[0]]=int(s1.split(":")[1])
print(dic)

5、元素分類有如下值li = [11, 22, 33, 44, 55, 66, 77, 88, 99, 90],將所有大於66
的值保存至字典的第一個key中,將小於66的值保存至第二個key的值中。即: {‘k1‘: 大於66的所有值列表, ‘k2‘: 小於66的所有值列表}
li = [11, 22, 33, 44, 55, 66, 77, 88, 99, 90]
li1=[]
li2=[]
dic={‘k1‘: "大於66的所有值列表," ,‘k2‘: "小於66的所有值列表"}
for a in li:
if a >66:
li1.append(a)
else:
li2.append(a)
dic["k1"]=str(li1)
dic["k2"]=str(li2)
print(dic)
6、輸出商品列表,用戶輸入序號,顯示用戶選中的商品

商品列表:
goods = [{"name": "電腦", "price": 1999},
{"name": "鼠標", "price": 10},
{"name": "遊艇", "price": 20},
{"name": "美女", "price": 998}, ]

要求:
1:頁面顯示序號 + 商品名稱 + 商品價格,如:1電腦1999
2鼠標10…
2:用戶輸入選擇的商品序號,然後打印商品名稱及商品價格
3:如果用戶輸入的商品序號有誤,則提示輸入有誤,並重新輸入。
4:用戶輸入Q或者q,退出程序。










明日默寫內容。

1)字典的增刪改查。
2)過濾敏感字符代碼的默寫。

li = ["蒼老師", "東京熱", "武藤蘭", "波多野結衣"]
l1 = []
comment = input(‘請輸入評論>>>‘)
for i in li:
if
i in comment:
comment = comment.replace(i, ‘*‘ * len(i))
l1.append(comment)
print(l1)

python學習內容.05