博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
day 5 作业
阅读量:5135 次
发布时间:2019-06-13

本文共 5042 字,大约阅读时间需要 16 分钟。

1,有如下变量(tu是个元祖),请实现要求的功能

tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11,22,33)}, 44])

a. 讲述元祖的特性

1)元祖tuple是一个只读列表,只可以查看,不可以修改增加和删除;

2)在定义只有一个元素的元祖时,要加上逗号以示和小括号的区别,如 age = (18, )

b. 请问tu变量中的第一个元素 “alex” 是否可被修改?

答:不可以,它直接属于元组tu的元素。

c. 请问tu变量中的"k2"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素 “Seven”

答:"k2"对应的值是列表类型;列表里面的元素可以被修改。

tu[1][2]['k2'].append('Seven') print(tu) 效果: ('alex', [11, 22, { 'k2': ['age', 'name', 'Seven'], 'k1': 'v1', 'k3': (11, 22, 33)}, 44])

d. 请问tu变量中的"k3"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素 “Seven”

答:"k3"对应的值是元组类型,不可以被修改。

强行修改会报错,告诉你元祖类型的对象没有append的方法。
如:

tu[1][2]['k3'].append('Seven') AttributeError: 'tuple' object has no attribute 'append' # 不过作为键值,k3对应的值倒可以被直接替换成另一个元祖数据,例如: # tu[1][2]['k3'] = (11, 22, 33, 'Seven' ) # print(tu) # 会显示出有Seven在的新元祖。

2, 字典dic,dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}

a. 请循环输出所有的keydic = {
'k1': "v1", "k2": "v2", "k3": [11, 22, 33]} for i in dic:   print(i) b. 请循环输出所有的value for i in dic.values(): print(i) c. 请循环输出所有的key和value for i in dic.items(): print(i) d. 请在字典中添加一个键值对,"k4": "v4",输出添加后的字典 dic['k4'] ='v4' print(dic) 效果: { 'k2': 'v2', 'k3': [11, 22, 33], 'k4': 'v4', 'k1': 'v1'} e. 请在修改字典中 “k1” 对应的值为 “alex”,输出修改后的字典 dic['k1'] = 'alex' print(dic) 效果: { 'k2': 'v2', 'k1': 'alex', 'k3': [11, 22, 33]} f. 请在k3对应的值中追加一个元素 44,输出修改后的字典 dic['k3'].append(44) print(dic) 效果: { 'k2': 'v2', 'k3': [11, 22, 33, 44], 'k1': 'v1'} g. 请在k3对应的值的第 1 个位置插入个元素 18,输出修改后的字典 dic['k3'].insert(0, 18) print(dic) 效果: { 'k3': [18, 11, 22, 33], 'k2': 'v2', 'k1': 'v1'}
 
 
 

 

3,

av_catalog = {    "欧美": {        "www.youporn.com": ["很多免费的,世界最大的", "质量一般"],        "www.pornhub.com": ["很多免费的,也很大", "质量比yourporn高点"],        "letmedothistoyou.com": ["多是自拍,高质量图片很多", "资源不多,更新慢"],        "x-art.com": ["质量很高,真的很高", "全部收费,屌丝请绕过"]    },    "日韩": {        "tokyo-hot": ["质量怎样不清楚,个人已经不喜欢日韩范了", "verygood"]    },    "大陆": {        "1024": ["全部免费,真好,好人一生平安", "服务器在国外,慢"]    }}

 

 

1,给此 ["很多免费的,世界最大的","质量一般"]列表第二个位置插入一个元素:'量很大'。
print(av_catalog['欧美']['www.youporn.com'])av_catalog['欧美']['www.youporn.com'].insert(1, '量很大')print(av_catalog['欧美']['www.youporn.com'])效果对比:['很多免费的,世界最大的', '质量一般']['很多免费的,世界最大的', '量很大', '质量一般']

 

2,将此 ["质量很高,真的很高","全部收费,屌丝请绕过"]列表的 "全部收费,屌丝请绕过" 删除。
print(av_catalog['欧美']['x-art.com'])av_catalog['欧美']['x-art.com'].pop()print(av_catalog['欧美']['x-art.com'])效果对比:['质量很高,真的很高', '全部收费,屌丝请绕过']['质量很高,真的很高']
3,将此 ["质量很高,真的很高","全部收费,屌丝请绕过"]列表的 "全部收费,屌丝请绕过" 删除。 同上..
4,将此["质量怎样不清楚,个人已经不喜欢日韩范了","verygood"]列表的 "verygood"全部变成大写。
print(av_catalog['日韩']['tokyo-hot'])av_catalog['日韩']['tokyo-hot'][1] = av_catalog['日韩']['tokyo-hot'][1].upper()print(av_catalog['日韩']['tokyo-hot'])效果对比:['质量怎样不清楚,个人已经不喜欢日韩范了', 'verygood']['质量怎样不清楚,个人已经不喜欢日韩范了', 'VERYGOOD']
5,给 '大陆' 对应的字典添加一个键值对 '1048' :['一天就封了']
print(av_catalog['大陆'])av_catalog['大陆'].setdefault('1048', ['一天就封了'])print(av_catalog['大陆'])效果对比:{
'1024': ['全部免费,真好,好人一生平安', '服务器在国外,慢']}{
'1048': ['一天就封了'], '1024': ['全部免费,真好,好人一生平安', '服务器在国外,慢']}
6,删除此"letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"]键值对。
av_catalog['欧美'].pop('letmedothistoyou.com')print('letmedothistoyou.com' in av_catalog['欧美'])返回的值是False,证明删除了。
7,给此["全部免费,真好,好人一生平安","服务器在国外,慢"]列表的第一个元素,加上一句话:'可以爬下来'
print(av_catalog['大陆']['1024'][0])av_catalog['大陆']['1024'][0] = av_catalog['大陆']['1024'][0] + '可以爬下来'可以简写成av_catalog['大陆']['1024'][0] += '可以爬下来' (和count += 1,自增一样)print(av_catalog['大陆']['1024'][0])显示对比:全部免费, 真好, 好人一生平安全部免费, 真好, 好人一生平安可以爬下来

 

 

 

4、有字符串"k:1|k1:2|k2:3|k3:4" 处理成字典 {'k':1,'k1':2....}

s = "k:1|k1:2|k2:3|k3:4"dic = {}a = s.split("|")print(a)for i in a:    print(i)    a,b = i.split(":")    dic[a]=bprint(dic) 结果:

['k:1', 'k1:2', 'k2:3', 'k3:4']

k:1
k1:2
k2:3
k3:4

{'k1': '2', 'k3': '4', 'k2': '3', 'k': '1'}

 

 

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]result = {}for el in li:    print(el)    if el < 66:        result.setdefault("key1",[]).append(el)    else:        result.setdefault("key2",[]).append(el)print(result) 结果:

11

22
33
44
55
66
77
88
99
90

 

{'key1': [11, 22, 33, 44, 55], 'key2': [66, 77, 88, 99, 90]}

 

 

6、输出商品列表,用户输入序号,显示用户选中的商品

goods = [{"name": "电脑", "price": 1999},

         {"name": "鼠标", "price": 10},
         {"name": "游艇", "price": 20},
         {"name": "美女", "price": 998}, ]

要求:

1:页面显示 序号 + 商品名称,如:

1 手机
2 电脑

goods = [{
"name": "电脑", "price": 1999}, {
"name": "鼠标", "price": 10}, {
"name": "游艇", "price": 20}, {
"name": "美女", "price": 998}, ]for i in range(len(goods)): print(i+1,goods[i]['name'],goods[i]['price'])

 

2: 用户输入选择的商品序号,然后打印商品名称

goods = [{
"name": "电脑", "price": 1999}, {
"name": "鼠标", "price": 10}, {
"name": "游艇", "price": 20}, {
"name": "美女", "price": 998}, ]for i in range(len(goods)): print(i+1,goods[i]['name'],goods[i]['price'])num = int(input("请输入你要买的序号:"))-1print(goods[num]['name'],goods[num]['price'])

 

3:如果用户输入的商品序号有误,则提示输入有误,并重新输入。

 

4:用户输入Q或者q,退出程序。

 
 

 

 

 

 

转载于:https://www.cnblogs.com/xiaomai-rhce/p/10333456.html

你可能感兴趣的文章
【Linux】ping命令详解
查看>>
对团队成员公开感谢博客
查看>>
java学习第三天
查看>>
django+uwsgi+nginx+sqlite3部署+screen
查看>>
浅谈项目需求变更管理
查看>>
经典算法系列一-快速排序
查看>>
设置java web工程中默认访问首页的几种方式
查看>>
ASP.NET MVC 拓展ViewResult实现word文档下载
查看>>
8、RDD持久化
查看>>
第二次团队冲刺--2
查看>>
Linux上架设boost的安装及配置过程
查看>>
[转载]加密算法库Crypto——nodejs中间件系列
查看>>
使用Xshell密钥认证机制远程登录Linux
查看>>
Android 画图之 Matrix(一)
查看>>
【模板】最小生成树
查看>>
设计模式之结构型模式
查看>>
使用pygal_maps_world.i18n中数据画各大洲地图
查看>>
jQuery EasyUI 的下拉选择combobox后台动态赋值
查看>>
timeline时间轴进度“群英荟萃”
查看>>
python if else elif statement
查看>>