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'}
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....}

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

铁乐学python_day05-作业的更多相关文章

  1. 铁乐学Python_day12_作业

    1.写函数,返回一个扑克牌列表,里面有52项,每一项是一个元组 例如:[('红心',2),('草花',2), -('黑桃','A')] def poker(): suit = ['红心', '梅花', ...

  2. 铁乐学python_day10_作业

    1.继续整理函数相关知识点,写博客. 2.写函数,接收n个数字,求这些参数数字的和.(动态传参) def sum_n(*args): sum = 0 for i in args: sum += i r ...

  3. 铁乐学python_day09_作业

    练习题 1.整理函数相关知识点,写博客 2.写函数,检查获取传入列表或元组对象的所有奇数位索引对应的元素, 并将其作为新列表返回给调用者. def odd_index(l): lis = [] for ...

  4. 铁乐学Python_day08作业

    1. 文件a.txt内容:每一行内容分别为商品名字,价钱,个数. apple 10 3 tesla 100000 1 mac 3000 2 lenovo 30000 3 chicken 10 3 通过 ...

  5. 铁乐学python_Day44_IO多路复用

    目录 IO模型介绍 阻塞IO(blocking IO) 非阻塞IO(non-blocking IO) 多路复用IO(IO multiplexing) 异步IO(Asynchronous I/O) IO ...

  6. 铁乐学python_Day43_协程

    铁乐学python_Day43_协程 引子 之前我们学习了线程.进程的概念,了解了在操作系统中进程是资源分配的最小单位,线程是CPU调度的最小单位. 按道理来说我们已经算是把cpu的利用率提高很多了. ...

  7. 铁乐学python_Day42_线程池

    铁乐学python_Day42_线程池 concurrent.futures 异步调用模块 concurrent.futures模块提供了高度封装的异步调用接口 ThreadPoolExecutor: ...

  8. 铁乐学python_Day42_线程-信号量事件条件

    铁乐学python_Day42_线程-信号量事件条件 线程中的信号量 同进程的一样,Semaphore管理一个内置的计数器, 每当调用acquire()时内置计数器-1:调用release() 时内置 ...

  9. 铁乐学python_Day42_锁和队列

    铁乐学python_Day42_锁和队列 例:多个线程抢占资源的情况 from threading import Thread import time def work(): global n tem ...

  10. 铁乐学python_Day39_多进程和multiprocess模块2

    铁乐学python_Day39_多进程和multiprocess模块2 锁 -- multiprocess.Lock (进程同步) 之前我们千方百计实现了程序的异步,让多个任务可以同时在几个进程中并发 ...

随机推荐

  1. Linux用户信息查询

    1 查询目前已登录的用户信息w 或者 who [@bjzw_11_210 ~]# w :: up days, :, users, load average: 0.03, 0.04, 0.00 USER ...

  2. TCP/IP协议栈概述及各层包头分析

    TCP/IP协议栈中各层包头的分析 Protocol列表示的是该数据包最高层对应的协议,Length列表示该包的长度(包括从底层的协议到最高层的协议,其中包头一般是,链路层14字节,IP20字节,TC ...

  3. 【LeetCode题解】237_删除链表中的节点

    目录 237_删除链表中的节点 描述 解法 思路 Java 实现 Python 实现 237_删除链表中的节点 描述 请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点,你将只被给定要求被删除 ...

  4. 默 of 2018:年终总结

    目录 1 概述:在平凡中求变 2 专业分流:一个时代的终点,我的新起点 2.1 我在专业分流前夕的境况 2.2 专业分流情况概述,以及对一篇文章的回顾 2.3 总结与余绪 2.4 附:关于理科与工科的 ...

  5. Linux下socket通信和epoll

    上一篇博客用多线程实现服务端和多个客户端的通信,但是在实际应用中如果服务端有高并发的需求,多线程并不是一个好选择. 实现高并发的一种方法是IO多路复用,也就是select,poll,epoll等等. ...

  6. 在 CentOS7 上安装 zookeeper-3.5.2 服务

    [root@centos-linux src]# pwd /usr/local/src # 1.创建 /usr/local/src/zookeeper 文件夹 [root@centos-linux s ...

  7. 关于Google圆角高光高宽自适应按钮及其拓展

    关于Google圆角高光高宽自适应按钮及其拓展————源自张鑫旭css讲解 这篇文章发布于 2009年10月24日,星期六,18:08,归类于 css相关. 阅读 48770 次, 今日 1 次 by ...

  8. GDAL线面互转换(2)

    在上一个文章中介绍了线转化为面和面转化为线,其主要的实现思路就是把面中的点取出来构成线,把线中的点取出来构成面,实际上就是一个硬拷贝,无奈客户的实际需求并非如此,客户想要线转面的时候几条相交线构成面, ...

  9. ORACLE 导出表结构及备注

    https://blog.csdn.net/u013303551/article/details/52354230 SELECT t.table_name,       t.colUMN_NAME,  ...

  10. 多表批量导出txt及打压缩包下载

     在一些特殊的业务系统中,有些客户查看报表数据时不需要在浏览器上逐一查看,需要在页面端选择要查看的报表名称(可多选),选择条件,然后将所选中的报表批量导出到txt文件中并且要把批量导出的结果文件打 ...