关于set集合做业: 写一个彩票开奖(36选7)
##题意理解:从1-36中随机产生7个不重复的数字做为开奖数字
from random import randintpython
randint(1,36)) #返回1-36之间的一个随机数,包括36
git
1,有以下变量(tu是个元祖),请实现要求的功能 服务器
tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11,22,33)}, 44])app
a. 讲述元祖的特性dom
b. 请问tu变量中的第一个元素 "alex" 是否可被修改?this
c. 请问tu变量中的"k2"对应的值是什么类型?是否能够被修改?若是能够,请在其中添加一个元素 "Seven"spa
d. 请问tu变量中的"k3"对应的值是什么类型?是否能够被修改?若是能够,请在其中添加一个元素 "Seven"code
2, 字典dic,dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}blog
a.请循环输出全部的key索引
b.请循环输出全部的value
c. 请循环输出全部的key和value
d. 请在字典中添加一个键值对,"k4": "v4",输出添加后的字典
e. 请在修改字典中 "k1" 对应的值为 "alex",输出修改后的字典
f. 请在k3对应的值中追加一个元素 44,输出修改后的字典
g. 请在k3对应的值的第 1 个位置插入个元素 18,输出修改后的字典
3,av_catalog = {
"欧美":{
"www.youporn.com": ["不少免费的,世界最大的","质量通常"],
"www.pornhub.com": ["不少免费的,也很大","质量比yourporn高点"],
"letmedothistoyou.com": ["可能是自拍,高质量图片不少","资源很少,更新慢"],
"x-art.com":["质量很高,真的很高","所有收费,屌丝请绕过"]
},
"日韩":{
"tokyo-hot":["质量怎样不清楚,我的已经不喜欢日韩范了","verygood"]
},
"大陆":{
"1024":["所有免费,真好,好人一辈子平安","服务器在国外,慢"]
}
}
a,给此 ["不少免费的,世界最大的","质量通常"]列表第二个位置插入一个 元素:'量很大'。
b,将此 ["质量很高,真的很高","所有收费,屌丝请绕过"]列表的 "所有收费,屌丝请绕过" 删除。
c,在此 ["质量很高,真的很高","所有收费,屌丝请绕过"]列表中添加"金老板最喜欢这个"。
d,将此["质量怎样不清楚,我的已经不喜欢日韩范了","verygood"]列表的 "verygood"所有变成大写。
e,给'大陆' 对应的字典添加一个键值对 '1048' :['一天就封了']
f,删除此"letmedothistoyou.com": ["可能是自拍,高质量图片不少","资源很少,更新慢"]键值对。
g,给此["所有免费,真好,好人一辈子平安","服务器在国外,慢"]列表的第一个元素,加上一句话:'能够爬下来'
四、有字符串 "k:1|k1:2|k2:3|k3:4" 处理成字典 {'k':1,'k1':2....} (升级题)
五、元素分类
有以下值li= [11,22,33,44,55,66,77,88,99,90],将全部大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值中。
即: {'k1': 大于66的全部值列表, 'k2': 小于66的全部值列表}
六、输出商品列表,用户输入序号,显示用户选中的商品(升级题)
商品列表:
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 = ["苍老师","东京热","武藤兰","波多野结衣"]
comment = input('请输入评论>>>')
for i in li:
if i in comment:
comment = comment.replace(i,'*'*len(i))
print(comment)
#!/Users/liangyufeng/venv/bin/python3 # _*_ coding:utf-8 _*_ ##课上留的做业 # 关于set集合做业: 写一个彩票开奖(36选7) ##题意理解:从1-36中随机产生7个不重复的数字做为开奖数字 from random import randint nums = set() #下面是相同的思想,不一样的代码堆砌方式 #方法1 while True: nums.add(randint(1,36)) #返回1-10之间的一个随机数,包括10 if len(nums) == 7: break print(nums) #方法2 while len(nums) != 7: # 或者<7 nums.add(randint(1,36)) print(nums) #老师讲的,其实仍是同样的思想 while len(nums) < 7: # 或者<7 nums.add(randint(1, 36)) print(nums) ''' for 和 while 的使用场合: for : 肯定循环范围或次数的用for. str, list, dic, tuple, set while: 不肯定循环次数的用 while.(while 能够无限循环,而 for 必定要给个循环的边界) ''' # day5做业及默写 # # 1,有以下变量(tu是个元祖),请实现要求的功能 # tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11,22,33)}, 44]) # a. 讲述元祖的特性 # 元组最大的特性就是元组的不可变: 指的是对内部元素的指向不变,若是内部的元素是可变的数据类型,则照样是可变的,这个和元组的不可变没有冲突. # b. 请问tu变量中的第一个元素 "alex" 是否可被修改?不能够 # c. 请问tu变量中的"k2"对应的值是什么类型?是否能够被修改?若是能够,请在其中添加一个元素 "Seven" tu[1][2]['k2'].append("Seven")#列表,能够修改 # d. 请问tu变量中的"k3"对应的值是什么类型?是否能够被修改?若是能够,请在其中添加一个元素 "Seven" # 元组,不能够修改 # 2, 字典dic, dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]} # a.请循环输出全部的key for k in dic: print(k) # b.请循环输出全部的value for v in dic.values(): print(v) # c. 请循环输出全部的key和value for k,v in dic.items(): print(k,v) # d. 请在字典中添加一个键值对,"k4": "v4",输出添加后的字典 dic["k4"] = "v4" # e. 请在修改字典中 "k1" 对应的值为 "alex",输出修改后的字典 dic["k1"] = "alex" # f. 请在k3对应的值中追加一个元素 44,输出修改后的字典 dic["k3"].append(44) print(dic) # g. 请在k3对应的值的第 1 个位置插入个元素 18,输出修改后的字典 dic["k3"].insert(1,18) 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"].insert(2,'量很大') # b,将此 ["质量很高,真的很高","所有收费,屌丝请绕过"]列表的 "所有收费,屌丝请绕过" 删除。 av_catalog["欧美"]["x-art.com"].remove("所有收费,屌丝请绕过") av_catalog["欧美"]["x-art.com"].pop(1) # c,在此 ["质量很高,真的很高","所有收费,屌丝请绕过"]列表中添加"金老板最喜欢这个"。 av_catalog["欧美"]["x-art.com"].append("金老板最喜欢这个") # d,将此["质量怎样不清楚,我的已经不喜欢日韩范了","verygood"]列表的 "verygood"所有变成大写。 av_catalog["日韩"]["tokyo-hot"][1] = av_catalog["日韩"]["tokyo-hot"][1].upper()#字符串不可变,改完以后要塞回去##这里千万不要忘记 # e,给'大陆' 对应的字典添加一个键值对 '1048' :['一天就封了'] av_catalog["大陆"]["1048"] = ['一天就封了'] # f,删除此"letmedothistoyou.com": ["可能是自拍,高质量图片不少","资源很少,更新慢"]键值对。 av_catalog["欧美"].pop("letmedothistoyou.com") del av_catalog["欧美"]["letmedothistoyou.com"] # g,给此["所有免费,真好,好人一辈子平安","服务器在国外,慢"]列表的第一个元素,加上一句话:'能够爬下来' av_catalog["大陆"]["1024"].insert(0,'能够爬下来')##老师是做为 insert这样讲的,可是我以为这里有歧义,这里的表述是对第一个元素,而不是对第一个位置 ##须要记忆 # 四、有字符串 "k:1|k1:2|k2:3|k3:4" 处理成字典 {'k':1,'k1':2....} (升级题) dic = {} s = "k:1|k1:2|k2:3|k3:4" for el in s.split('|'): #['k:1','k1:2','k2:3,'k3:4'] k, v = el.split(':') #解构 k,v = el[0],el[-1] dic[k] = int(v) print(dic) #老师的更详细 s = 'k:1|k1:2|k2:3|k3:4' lst = s.split('|') # print(lst) #['k:1', 'k1:2', 'k2:3', 'k3:4'] dic = {} for item in lst: # print(item) # k:1 k1:2 k2:3 k3:4 k,v = item.split(':') #['k','1'] dic[k] = int(v) print(dic) ##要理解记忆 # 五、元素分类 # 有以下值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] # 方法一 dic = {'k1': [], 'k2': []} # 这里直接定义了字典中的全部键值对,有一个缺点是若是题目要将值分到更多的键值对中要写不少,很麻烦,无论是本身开始就定义好仍是以后本身手加新的键值对 for i in li: if i > 66: dic['k1'].append(i) elif i < 66: dic['k2'].append(i) print(dic) # #方法二 利用字典的 get 方法,当键不存在时候返回None,是False dic = {} for item in li: if item > 66: if dic.get('key1'): # key1 存在直接添加元素 dic['key1'].append(item) else: dic['key1'] = [item] # key1不存在建立并添加元素(实际上是建立一个带元素的列表) elif item < 66: if dic.get('key2'): # key2 存在直接添加元素 dic['key2'].append(item) else: dic['key2'] = [item] # key2不存在建立并添加元素 # 方法三 这个方法要记忆 利用 setdefault 方法的查询和添加功能 dic = {} for item in li: if item > 66: #首先判断 key1是否存在.一开始是不存在的,根据 key1将[]添加到字典中,而后执行查询操做返回[],再执行 append() #第二次走到这里,直接根据 key1查询出列表,就执行 append() dic.setdefault('key1', []).append(item) elif item < 66: dic.setdefault('key2', []).append(item) print(dic) # 六、输出商品列表,用户输入序号,显示用户选中的商品(升级题) # 商品列表: # goods = [{"name": "电脑", "price": 1999}, # {"name": "鼠标", "price": 10}, # {"name": "游艇", "price": 20}, # {"name": "美女", "price": 998}, ] # 要求: # 1:页面显示 序号 + 商品名称 + 商品价格,如: # 1 电脑 1999 # 2 鼠标 10 # … # 2:用户输入选择的商品序号,而后打印商品名称及商品价格 # 3:若是用户输入的商品序号有误,则提示输入有误,并从新输入。 # 4:用户输入Q或者q,退出程序。 #我写的 goods = [{"name": "电脑", "price": 1999}, {"name": "鼠标", "price": 10}, {"name": "游艇", "price": 20}, {"name": "美女", "price": 998}, ] while 1: for i in range(len(goods)): print('%s %s %s'%(i+1,goods[i]['name'],goods[i]['price'])) num = input('请输入要选择的商品序号(Q退出程序):').strip() if num.isdigit(): num = int(num) if num < len(goods): print('%s %s'%(goods[num-1]['name'],goods[num-1]['price'])) else: print('商品序号有误,请从新输入') elif num.upper() == 'Q': break else: print('输入有误,请从新输入') #老师讲解的,想法没差,就看代码的具体实现 goods = [{"name": "电脑", "price": 1999}, {"name": "鼠标", "price": 10}, {"name": "游艇", "price": 20}, {"name": "美女", "price": 998}] for i in range(len(goods)): good = goods[i] # {"name": "电脑", "price": 1999} print(i+1, good['name'], good['price']) while 1: content = input('请输入你要选择的商品的序号:') if content.upper() == "Q": print("结束购物") break # 判断若是输入的不是数字 或者超过了商品的序号范围 if not content.isdigit() or int(content) > len(goods) or int(content) <= 0: print("对不起, 您输入的内容有误. 请从新输入") continue # 从新执行循环 num = int(content) # 转换成数字 # 还原索引 index = num - 1 good = goods[index] # 根据索引找到你购买的商品 {"name": "美女", "price": 998} print(f"您要购买的商品名称是{good['name']}, 商品的价格是{good['price']}") # 明日默写内容。 # # 1)字典的增删改查。 ''' 1. 添加 dic[新key] = 值 setdefault(key,value) key不存在,添加键值对 2. 删除 pop(key) 删除指定键的键值对 ## dic.popitem() # 随机删除一项(如今的版本通常是弹出最后一项) ##del dic["李安"] ##dic.clear() # 清空 3. 修改 dic[老key] = (新)值 update() 更新字典(迭代更新,相似于列表的 extend) 4. 查询 dic[key] ##直接使用key就能够拿到value get(key, 值) ##当key不存在. 返回第二个参数. 默认第二个参数是None setdefault(key, value) key存在,返回对应的 value,key 不存在,先新增,再返回对应的 value 5. 遍历 # 1. 使用for循环直接遍历字典的key # for key in dic: # print(key) # print(dic[key]) # 2. 可使用字典的items()+解构能够直接获取到key和value # for k, v in dic.items(): # print(k) # print(v) ''' # 2)过滤敏感字符代码的默写。 li = ["苍老师","东京热","武藤兰","波多野结衣"] comment = input('请输入评论>>>') for i in li: if i in comment: comment = comment.replace(i,'*'*len(i)) print(comment)