day5作业及默写
1,有如下变量(tu是个元祖),请实现要求的功能
tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11,22,33)}, 44])
a. 讲述元组的特性
1 1、元组是通过小括号将元素括起来的表现形式 2 2、元组是不可变数据类型 3 3、元组可切片,可迭代
b. 请问tu变量中的第一个元素 "alex" 是否可被修改?
不能
c. 请问tu变量中的"k2"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素 "Seven"
1 列表list,可以,tu[1][2]["k2"].append("Seven")
d. 请问tu变量中的"k3"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素 "Seven"
元组,不可修改
2, 字典dic,dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}
a. 请循环输出所有的key
for key in dic.keys():
print(key)
b. 请循环输出所有的value
for value in dic.values():
print(value)
c. 请循环输出所有的key和value
for k,v in dic.items():
print(k,v)
d. 请在字典中添加一个键值对,"k4": "v4",输出添加后的字典
dic["k4"] = "v4";print(dic)
e. 请在修改字典中 "k1" 对应的值为 "alex",输出修改后的字典
dic["k1"] = "alex";print(dic)
f. 请在k3对应的值中追加一个元素 44,输出修改后的字典
dic["k3"].append(44);print(dic)
g. 请在k3对应的值的第 1 个位置插入个元素 18,输出修改后的字典
dic["k3"].insert(0,18);print(dic)
1. av_catalog = {
"欧美":{
"1. www.youporn.com": ["很多免费的,世界最大的","质量一般"],
"1. www.pornhub.com": ["很多免费的,也很大","质量比yourporn高点"],
"letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"],
"x-art.com":["质量很高,真的很高","全部收费,屌丝请绕过"]
},
"日韩":{
"tokyo-hot":["质量怎样不清楚,个人已经不喜欢日韩范了","verygood"]
},
"大陆":{
"1024":["全部免费,真好,好人一生平安","服务器在国外,慢"]
}
}
a,给此 ["很多免费的,世界最大的","质量一般"]列表第二个位置插入一个 元素:'量很大'。
av_catalog.get("欧美").get("www.youporn.com").insert(1, "量很大")
b,将此 ["质量很高,真的很高","全部收费,屌丝请绕过"]列表的 "全部收费,屌丝请绕过" 删除。
av_catalog.get("欧美").get("x-art.com").remove("全部收费,屌丝请绕过")
c,将此 ["质量很高,真的很高","全部收费,屌丝请绕过"]列表的 "全部收 费,屌丝请绕过" 删除。
d,将此["质量怎样不清楚,个人已经不喜欢日韩范了","verygood"]列表的 "verygood"全部变成大写。
av_catalog.get("日韩").get("tokyo-hot")[1] = av_catalog.get("日韩").get("tokyo-hot")[1].upper()
e,给 '大陆' 对应的字典添加一个键值对 '1048' :['一天就封了']
av_catalog.get("大陆")["1048"] = ['一天就封了']
f,删除此"letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"]键值对。
del av_catalog.get("欧美")["letmedothistoyou.com"]
g,给此["全部免费,真好,好人一生平安","服务器在国外,慢"]列表的第一个元素,加上一句话:'可以爬下来'
av_catalog.get("大陆").get("1024")[0] = av_catalog.get("大陆").get("1024")[0] + '可以爬下来'
4、有字符串"k:1|k1:2|k2:3|k3:4" 处理成字典 {'k':1,'k1':2....}
1 dic = {} 2 str_01 = "k:1|k1:2|k2:3|k3:4" 3 str_list = str_01.split("|") 4 for i in str_list: 5 k,v = i.split(":") 6 dic[k] = int(v) 7 print(dic)
5、元素分类
有如下值li= [11,22,33,44,55,66,77,88,99,90],将所有大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值中。
即: {'k1': 大于66的所有值列表, 'k2': 小于66的所有值列表}
1 dic = {} 2 k1_value = [] 3 k2_value = [] 4 for i in li: 5 if i > 66: 6 k1_value.append(i) 7 elif i < 66: 8 k2_value.append(i) 9 dic["k1"] = k1_value 10 dic["k2"] = k2_value 11 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:输出商品列表: 序号 + 商品名称 + 商品价格
1 counts = 0 2 flag = 1 3 for i in goods: 4 print(counts+1,"\t",goods[counts]["name"],"\t",goods[counts]["price"]) 5 counts += 1 6 # 2:用户输入选择的商品序号,然后打印商品名称及商品价格 7 while flag: 8 choice = input("请输入您的商品序号:(输入Q或q退出)") 9 if choice.upper() == "Q": 10 flag = 0 11 else: 12 if not choice.isdigit(): 13 print("序号输入错误,请重新输入:") 14 continue 15 elif int(choice) > len(goods): 16 print("序号输入错误,请重新输入:") 17 continue 18 else: 19 print("商品名称为:",goods[int(choice) -1]["name"],"商品价格为:",goods[int(choice) -1]["price"]) 20 flag = 0
注意:
1、goods[count +1] 其实就是for里的i
2、用户输入要去掉空格等字符 choice.strip()
3、判断输入的是不是数字和输入的数字是不是商品序号范围放在一起即 if choice.isdigit() and choice >=1 and choice < len(li)
明日默写内容。
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)