zl程序教程

您现在的位置是:首页 >  后端

当前栏目

python_day05-作业详解编程语言

Python编程语言 详解 作业 day05
2023-06-13 09:20:37 时间
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. 请循环输出所有的key 

dic = {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}

"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 .}
k = "k:1|k1:2|k2:3|k3:4" 

dk = { } 

for i in k.strip().split(|): 

 i = i.stsrip().split(:) 

 # print(i) 调试用, 

 # i[0]之类己经是直接指代字符串了,不需要再加引住。i[1]注意要int转换成整数型。 

 dk.setdefault(i[0], int(i[1])) 

print(dk) 

s = k:1|k1:2|k2:3|k3:4 

dic = {} 

for i in s.strip().split(|): 

 i = i.stsrip().split(:) 

dic[i[0].strip()] = int(i[1]) 

print(dic) 

{k2: 3, k1: 2, k3: 4, 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] 

dic = { } 

l1 = [ ] 

l2 = [ ] 

for i in li: 

 if i 66: 

 l1.append(i) 

 if i 66: 

 l2.append(i) 

#print(l1, l2) 

dic.setdefault(k1, l1) 

dic.setdefault(k2, l2) 

print(dic) 

{k2: [11, 22, 33, 44, 55], k1: [77, 88, 99, 90]} 

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) 

 if i 66: 

 dic[k2].append(i) 

print(dic) 

扩展:(直接在for循环里实施添加,而不是提前生成了一个字典) 

li = [11, 22, 33, 44, 55, 77, 88, 99, 90] 

result = {} 

for row in li: 

 result.setdefault(k1, []) 

 result.setdefault(k2, []) 

 if row 66: 

 result[k1].append(row) 

 if row 66: 

 result[k2].append(row) 

print(result)

6、输出商品列表,用户输入序号,显示用户选中的商品
商品 li = [ 手机 , 电脑 , 鼠标垫 , 游艇 ]
要求:1:页面显示 序号 + 商品名称,如:
1 手机
2 电脑

2: 用户输入选择的商品序号,然后打印商品名称
3:如果用户输入的商品序号有误,则提示输入有误,并重新输入。
4:用户输入Q或者q,退出程序。

li = ["手机", "电脑", 鼠标垫, 游艇] 

while True: 

for i in range(len(li)): 

 print(str(i+1) +   + li[i]) 

 sn = input(选择商品序号(按Q/q回车退出):).strip().upper() 

 if sn == Q: 

 print("请慢走") 

 break 

 if not sn.isdigit() or int(sn) len(li): 

 print(请重新输入正确的商品序列号:) 

 continue 

 print(li[int(sn)-1]) 

上面的考虑还不够周全,没有考虑到输入0的情况。 

li = ["手机", "电脑", 鼠标垫, 游艇] 

while True: 

 for i in li: 

 print({}/t{}.format(li.index(i)+1, i)) #格式化输出,中间多了个空格符 

 num = input(请输入商品序号:q/Q退出 ).strip() 

 if num.isdigit(): 

 num = int(num) 

 if num 0 and num = len(li): 

 print(li[num - 1]) 

 else: 

 print(你输入的选项超出范围,请重新输入) 

 elif num.upper() == Q:break 

 else: 

 print(输入的有非法数字,请重新输入)

明日默写内容。
1)字典的增删改查。
增:1) dict[ key ] = value 有则覆盖,无则添加
2) dict.setdefault( key , value ) 有则不改,无则添加
删:1) dict.pop( key ) 通过键删除值
2) dict.clear() 清空字典
3)del dict[ key ] 通过键删除键值对
del dict 删除字典
4)dict.popitem() 随机删除
改 1)dict[ key ] = value 和增的第一种方法一样,直接修改键来变动值
2)dict.update(dict2) 将dict2键/值对,更新(覆盖有的,无的添加)到dict
查 1)dict[ key ] 通过键返回的是你要查的值,但是要注意的是若没有查询的键会报错。
2)dict.get( key ,default=None) 同样通过键查值,但用这个查没有的键时返回的是自定义的值。
3)dict.keys() 以列表方式返回字典中所有的键。
4)dict.values() 以列表方式返回字典中所有的值。
5)dict.items() 以列表方式返回可遍历的键值对。分别成对放在元组中。

2)过滤敏感字符代码的默写。

li = ["苍老师","东京热","武藤兰","波多野结衣"] 

l1 = [] 

comment = input(请输入评论 ) 

for i in li: 

 if i in comment: 

 comment = comment.replace(i,**len(i)) 

l1.append(comment) 

print(l1)

end
2018-3-22

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/12774.html

cgopython