练习题2
1.统计元组中所有数据属于字符串串的个数,提示:isinstance()
数据:t1 = (1, 2, ‘3’, ‘4’, 5, ‘6’)
结果:3
t1 = (1, 2, '3', '4', 5, '6')
num = 0
for i in t1:
if isinstance(i, str):
num += 1
print("总共有%s个字符串" % num)
2.将以下数据存储为字典类型
数据:info = “name:Owen|age:18|gender:男”
结果:{‘name’: ‘Owen’, ‘age’: 18, ‘gender’: ‘男’}
注:年年龄存储为数字类型
info = "name:Owen|age:18|gender:男"
new_dic = {}
for i in info.split("|"):
l1 = i.split(":")
if l1[1].isdecimal():
new_dic[l1[0]] = int(l1[1])
else:
new_dic[l1[0]] = l1[1]
print(new_dic)
3.完成数据的去重
数据:t3 = (1, 2, 1, 2, 3, 5, 9)
结果:t3 = (1, 2, 3, 5, 9)
注:从不不考虑顺序、考虑顺序两⽅方⾯面完成
t3 = (1, 2, 1, 2, 3, 5, 9)
res = set()
for i in t3:
res.add(i)
print(tuple(res))
4.计算元组中所有可以转换为数字的数据的总和
数据:t4 = (10, ‘abc’, ‘100’, ‘3’)
运算结果:113
sum = 0
t4 = (10, 'abc', '100', '3')
for i in t4:
if isinstance(i, int) or i.isdecimal():
i = int(i)
sum += i
print("运算结果:", sum)
5.将数据转换类型存储
原数据:dic = {‘name’: ‘Owen’, ‘age’: 18, ‘gender’: ‘男’}
处理理后:info = [(‘name’, ‘Owen’), (‘age’, 18), (‘gender’, ‘男’)]
dic = {'name': 'Owen', 'age': 18, 'gender': '男'}
info = []
for k,v in dic.items():
info.append(tuple([k, v]))
print(info)
拓拓展:选做
1.计算元组中所有可以转换为数字的数据的总和
数据:t4 = (10, ‘abc’, ‘100’, ‘3’, ‘壹’, ‘肆’, [1000], (10000,))
运算结果:11118
提示:
– 利利⽤用字符串串isnumeric()判断汉字
– 利利⽤用字典{‘壹’: 1 …}将汉字转换为数字
– 利利⽤用isinstance()将list和tuple中数据取出来
– 先将所有转化为数字的数据存放在⼀一个单列列集合中,在做运算
t4 = (10, 'abc', '100', '3', '壹', '肆', [1000], (10000,))
res = []
dic = {'壹': 1, '肆': 4}
for i in t4:
if isinstance(i, int):
res.append(i)
elif isinstance(i, str):
if i.isdecimal():
res.append(int(i))
elif i.isnumeric():
res.append(dic[i])
elif isinstance(i, list):
for y in i:
res.append(y)
elif isinstance(i, tuple):
for y in i:
res.append(y)
print("运算结果: ", sum(res))
2.完成录入电话本
需求:
‘’’
– 从键盘中录入姓名(不区分大小写):
– 姓名必须是全英文组成,不是则重新录入姓名,如果是q,代表退出
– 从键盘中再录入电话:
– 电话必须为数字且长度必须是11位(不能转换为数字)
– 如果出现姓名相同,则保留最后一次电话号码
– 形成的数据是有电话分组的,如:第一次录入Owen,13355667788,则会形成
– {
‘O’: {
‘Owen’: ‘13355667788’
}
}
最终数据,分组名⼀一定⼤大写:
{
‘E’: {
‘egon’: ‘17788990000’,