python中元组、字典、集合的应用

一、元组

1、元组的创建

元组(tuple):带了紧箍咒的列表
元组本身不可变数据类型,没有增删改差
元组内可以存储任意数据类型

t = (1,2,3,4.0,’star’)
print t,type(t)

元组里面包含可变数据类型,可以间接修改元组的内容
t1 = ([1,2,3],4)
t1[0].append(4)
print t1

元组如果只有一个元素的时候,后面一定要加逗号,否则数据类型不确定
t2 = (‘hello’,)
t3 = (1,)
print type(t2),type(t3)

2、元组的特性

allowUsers = (‘root’,’westos’,’fentiao’)
allowPasswd = (‘123’,’456’,’789’)

索引 切片
print allowUsers[0]
print allowUsers[-1]
print allowUsers[1:]
print allowUsers[2:]
print allowUsers[:-1]
print allowUsers[::-1]

重复
print allowUsers * 3
# 连接
print allowUsers + (‘fensi’,’fendai’)
# 成员操作符
print ‘westos’ in allowUsers
print ‘westos’ not in allowUsers

3、元组的应用场景

1.变量交换数值
a = 1
b = 2
b,a = a,b
先把(a,b)封装成了一个元组(1,2)
b,a = a,b
b =(1,2)[0] a=(1,2)[1]
print a,b

# 2.打印变量值
# name = ‘westos’
# age = 10
# t = (name,age)
# print ‘name: %s,age: %d’ %(name,age)
# print ‘name: %s,age: %d’ %t

# 3.元组的赋值:有多少个元素,就用多少个变量接收
# t = (‘westos’,10,100)
# name,age,score = t
# print name,age,score

scores = (100,89,45,78,65)
# scoresLi = list(scores)
# scoresLi.sort()
# print scoresLi
scores = sorted(scores)
print scores

二、集合

1、集合的定义
# 集合里面的元素是不可重复的
s = {1,2,3,1,2,3,4,5}
print s,type(s)
s1 = {1}
print s1,type(s1)
# 如何定义一个空集合
# s2 = {}
# print type(s2)
s3 = set([])
print s3,type(s3)

# 集合的应用
li = [1,2,3,1,2,3]
print list(set(li))

2、集合的特性
集合只支持 成员操作符 for循环
s = {1,2,3}
#print s[0]
# print s * 3
# print s + {5,4,6}
print 1 in s
for i in s:
print i,
for i,v in enumerate(s):
print ‘index: %s,value:%s’ %(i,v)

3、集合的常用方法
s = {6, 7, 8, 1, 2, 3}
# 增加
# s.add(10)
# s.add(9)
# print s
# 增加多个元素
# s.update({4,5})
# print s
# 删除
# print s
# s.pop()
# print s
# 删除指定的元素
# s.remove(2)
# print s

# 交集 并集 差集
s1 = {1, 2, 3}
s2 = {2, 3, 4}

# 并集
print ‘并集:’, s1.union(s2)
print ‘并集:’, s1 | s2

# 交集
print ‘交集:’, s1.intersection(s2)
print ‘交集:’, s1 & s2

# 差集
# 可以理解为s1中有哪些s2中没有的元素
print ‘差集:’, s1.difference(s2) # s1-(s1&s2)
print ‘差集:’, s1 - s2
# 可以理解为s2中有哪些s1中没有的元素
print ‘差集:’, s2.difference(s1) # s2-(s1&s2)
print ‘差集:’, s2 - s1

# 对等差分:并集-交集
print ‘对等差分:’, s1.symmetric_difference((s2))
print ‘对等差分:’, s1 ^ s2

s3 = {1, 2}
s4 = {1, 2, 3}

# s3是否为s4的子集
print s3.issubset(s4)
# s3是否为s4的超集
**# 什么是超集:如果s3中的每一个元素都在集合s4中,且 s4中可能包含s3中没有的元素,则s3就是s4的一个超集
print s3.issuperset(s4)

# 两个集合是不是不相交
print s3.isdisjoint(s4)

4、集合的练习
华为机测题:
明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性
他先用计算机生成了N个1~1000之间的随机整数(N<=1000),N是用户输入的,对于
其中重复的数字,只保留一个,把其余相同的数字去掉,不同的数对应着不同的学生的学号,然后再把这些
数从小到大排序,按照排好的顺序去找同学做调查,请你协助明明完成“去重”与排序工作

import random
# 先 生成n个随机数
# 优先选择集合
s = set([])
for i in range(int(raw_input(‘N:’))):
# num = random.randint(1,1000)
# s.add(num)
s.add(random.randint(1,1000))
print s
print sorted(s)

三、字典

1、字典的定义
字典是一个无序的数据集合,使用print输出字典的时候通常输出的顺序和定义的顺序是不一致的
message = {
‘name’:’tom’,
‘age’:18,
‘height’:1.80,
‘weight’:75.5
}
print message

s = {}
print type(s)
s = {
‘fentiao’:[100,90,80],
‘westos’:[199,199,199]
}
print s

d = dict()
print d,type(d)

d = dict(a=1,b=2)
print d,type(d)

2、字典的特性
d = dict(a=1,b=2)
print d
成员操作符(默认判断key值是否存在)
print ‘a’ in d
print 1 in d
for循环(默认循环遍历字典的key值)
for i in d:
print i

3、字典的增加
d = dict(a=1, b=2)
print d
# 添加或者更改key-value对
d[‘g’] = 10
print d
d[‘a’] = 10
print d
“””
update:
如果key值存在,更新value值
如果key值不存在,添加key-value值
“””
d.update({‘a’:4,’f’:1})
print d

“””
setdefault
如果key值已经存在,不做修改
如果key值不存在,添加key-value值
“””
d.setdefault(‘a’,10)
print d

4、字典的删除
d = dict(a=1, b=2,c=3,d=4,e=5,f=6,g=7,h=8,i=9,j=10)
#pop:弹出指定的key-value值
d.pop(‘a’)
print d
popitem:随机弹出字典中的一个key-value值
pop_obj=d.popitem()
print pop_obj
print d
pop_obj=d.popitem()
print pop_obj
print d

del d[‘a’]
print d
clear:清除字典中的所有项
d.clear()

5、字典的修改与查看
service = {
‘http’:80,
‘mysql’:3306
}
# 查看字典里面所有的key值
print service.keys()
# 查看字典里面所有的value值
print service.values()
# 查看字典里面所有的key-value值
print service.items()
# 遍历
for k,v in service.items():
print k,’—->’,v
for k in service:
print k,’—–>’,service[k]

# print service[‘https’]
# if ‘https’ in service:
# print service[‘https’]
**# else:
# print ‘key not exist’

“””
get方法获取指定key对应的value值
如果key值存在,返回对应的value值
如果key值不存在,默认返回None,如果需要指定返回值,传值即可
“””
print service.get(‘http’,’key not exist’)

6、字典的练习
1).重复的单词: 此处认为单词之间以空格为分隔符, 并且不包含,和.;
1. 用户输入一句英文句子;
2. 打印出每个单词及其重复的次数;
“hello java hello python”
hello 2
java 1
python 1
s = raw_input(’s:’)

# 1.把每个单词分割处理
s_li = s.split()
print s_li
# 2.通过字典存储单词和该单词出现的次数
words_dict = {}
“””
依次循环遍历列表
如果列表元素不在字典的key中,将元素作为key 1作为valus值
如果列表元素在字典的key中,直接更新元素value值,在原有的基础上加1
“””
for item in s_li:
if item not in words_dict:
words_dict[item] = 1
else:
words_dict[item] += 1
# 4.打印生成的字典
print words_dict

2).数字重复统计:
1). 随机生成1000个整数;
2). 数字的范围[20, 100],
3). 升序输出所有不同的数字及其每个数字重复的次数;

import random
# 1.随机生成1000个整数
all_nums = []
for item in range(1000):
# 2.数字的范围
all_nums.append(random.randint(20, 100))
# 3.升序输出所有不同的数字及其每个数字重复的次数
sorted_num = sorted(all_nums)
nums_dict = {}
for num in sorted_num:
if num in nums_dict:
nums_dict[num] += 1
else:
nums_dict[num] = 1
print nums_dict

猜你喜欢

转载自blog.csdn.net/weixin_42915309/article/details/82460017
今日推荐