一:基本使用:tuple
1 用途:记录多个值,当多个值没有改的需求,此时用元组更合适
2 定义方式:在()内用逗号分隔开多个任意类型的值
t=(1,1.3,'xx',('a','b'),[1,2]) #t=tuple((1,1.3,'xx',('a','b'),[1,2])) # print(t,type(t)) # t1=tuple('hello') # print(t1)
# 3 常用操作+内置的方法
#优先掌握的操作
1、按索引取值(正向取+反向取):只能取
t=('egon',123,['a','b']) # print(id(t[0])) # print(id(t[1])) # print(id(t[2])) # # t[2][0]='A' # print('='*50) # print(id(t[0])) # print(id(t[1])) # print(id(t[2])) # # t[0]='EGON' # # # t[2]='xxxx' # # t[2][0]='A' # # print(t)
2、切片(顾头不顾尾,步长)
# t=(1,2,3,4,5) # print(t[0:3]) # print(t)
3、长度
4、成员运算in和not in
5、循环
# for item in ('a','b','c'): # print(item)
需要掌握的操作
# t=('a','b','c','a') # print(t.count('a')) # print(t.index('a',1,10)) # print(t.index('xxx',1,10))
该类型总结:
# 1 存多个值 # 2 有序 # # 3 不可变
三、字典类型
不可变类型=》可hash类型
可变类型 =》不可以hash类型
一:基本使用dict
1 用途:记录多个值,每一个值都对应的key用来描述value的作用
2 定义方式:在{}内用逗号分隔开多 个key:value,其中value可以是任意类型,而key必须是不可变的类型,通常情况下应该str类型
# dic={0:'aaa',1:'bbb',2:'cccc'} #dic=dict({0:'aaa',1:'bbb',2:'cccc'}) # print(dic,type(dic)) # print(dic[0]) # dic={[1,2]:'aaa'} # dic={(1,2):'aaa'} # print(dic[(1,2)])
用法二:
# userinfo=[ # ['name','egon'], # ['age',18], # ['sex','male'] # ] # d={} # for k,v in userinfo: #k,v=['name', 'egon'] # # print(k,v) # d[k]=v # print(d) # d=dict(userinfo) # print(d)
常用操作+内置的方法
1、按key存取值:可存可取
# dic={'name':'egon'} # print(dic['name']) # dic['name']='EGON' # print(dic) # dic['age']=18 # print(dic)
# l=['a','b']
# l[0]='A'
# l[2]='c'
2、长度len
3、成员运算in和not in:字典的成员运算判断的是key
4、删除
# del dic['name'] # print(dic) # del dic['xxx'] ##key不存在则报错 # res=dic.pop('age') #删除key对应的value,并返回value # print(dic) # print(res) # # dic.pop('xxx') #key不存在则报错 # res=dic.popitem() 随机删除 # print(dic) # print(res)
5、键keys(),值values(),键值对items()
dic={'name':'egon','age':18,} # print(dic.keys()) # l=[] # for k in dic.keys(): # l.append(k) # print(l) # print(list(dic.keys())) # print(dic.values()) # print(list(dic.values())) # print(dic.items()) # print(list(dic.items()))
6、循环
dic={'name':'egon','age':18,'sex':'male'} # for k in dic.keys(): # print(k,dic[k]) # for k in dic: # print(k,dic[k]) # for v in dic.values(): # print(v) # for k,v in dic.items(): # print(k,v)
7、dic.get()
dic={'name':'egon','age':18,'sex':'male'} # dic['xxx'] # v=dic.get('name') # print(v) # v=dic.get('xxx') # print(v)
# 需要掌握的操作
# dic.fromkeys()的用法: # l=['name','age','sex'] # dic={'name':None,'age':None,'sex':None} # dic={} # for k in l: # dic[k]=None # print(dic) # dic=dic.fromkeys(l,None) # print(dic)
setdefault:有则不动/返回原值,无则添加/返回新值
# dic={'name':'egon','age':18}
# res=dic.setdefault('name','EGON') # 字典中已经存在key则不修改,返回已经存在的key对应的value
# print(dic)
# print(res)
# res=dic.setdefault('sex','male') # 字典不存在key则添加"sex":"male",返回新的value
# print(dic)
# print(res)
# nums=[11,22,33,44,55,66,77,88,99,90] # dic={ # 'k1':[], # 'k2':[] # } # for num in nums: # if num > 66: # dic['k1'].append(num) # else: # dic['k2'].append(num) # print(dic) #
二:该类型总结
1 存多个值
2 无序
3 可变
# 练习1:
nums=[11,22,33,44,55,66,77,88,99,90] # dic={ # 'k1':[], # 'k2':[] # } # for num in nums: # if num > 66: # dic['k1'].append(num) # else: # dic['k2'].append(num) # print(dic) #
# s='hello alex alex say hello sb sb' # words=s.split() # dic={} # # print(words) # for word in words: # if word in dic: # dic[word]+=1 # else: # dic[word]=1 # # print(dic)
三、:基本使用:set
1 用途: 关系运算,去重
2 定义方式: 在{}内用逗号分开个的多个值
集合的三大特性:
2.1 每一个值都必须是不可变类型
2.2 元素不能重复
2.3 集合内元素无序
取及报名python课程又报名linux课程的学员:交集 # print(pythons & linuxs) # print(pythons.intersection(linuxs)) # 取所有报名老男孩课程的学员:并集 # print(pythons | linuxs) # print(pythons.union(linuxs)) # 取只报名python课程的学员: 差集 # print(pythons - linuxs) # print(pythons.difference(linuxs)) # 取只报名linux课程的学员: 差集 # print(linuxs - pythons) # print(linuxs.difference(pythons)) # 取没有同时报名两门课程的学员:对称差集 # print(pythons ^ linuxs) # print(pythons.symmetric_difference(linuxs)) # 是否相等 # s1={1,2,3} # s2={3,1,2} # print(s1 == s2) # 父集:一个集合是包含另外一个集合 # s1={1,2,3} # s2={1,2} # print(s1 >= s2) # print(s1.issuperset(s2)) # s1={1,2,3} # s2={1,2,4} # print(s1 >= s2) # 子集 # s1={1,2,3} # s2={1,2} # print(s2 <= s1) # print(s2.issubset(s1)) # 需要掌握操作 # s1={1,2,3} # s1.update({3,4,5}) # print(s1) # s1={1,2,3} # res=s1.pop() # print(res) # s1={1,2,3} # res=s1.remove(3) #单纯的删除,返回值为None # print(s1) # s1={1,2,3} # s1.add(4) # print(s1) # s1={1,2,3} # s2={1,2} # s1.difference_update(s2) #s1=s1.difference(s2) # print(s1) # s1={1,2,3} # res=s1.discard(3) ##单纯的删除,返回值为None # print(s1) # print(res) # s1.remove(444444) #删除的元素不存在则报错 # s1.discard(444444) #删除的元素不存在不会报错 # s1={1,2,3} # s2={1,2,4} # print(s1.isdisjoint(s2)) #如果两个集合没有交集则返回True # s1={1,2,3} # s2={4,5,6} # print(s1.isdisjoint(s2)) #如果两个集合没有交集则返回True #二:该类型总结 # 1 存多个值 # # 2 无序 # # 3 set可变 # s={1,2,3} # print(id(s)) # s.add(4) # print(id(s)) # 集合去重 # 局限性 #1、无法保证原数据类型的顺序 #2、当某一个数据中包含的多个值全部为不可变的类型时才能用集合去重 # names=['alex','egon','alex','alex','egon','lxx'] # s=set(names) # print(s) # l=list(s) # print(l) stus_info=[ {'name':'egon','age':18}, {'name':'alex','age':73}, {'name':'oldboy','age':84}, {'name': 'egon', 'age': 18}, {'name': 'egon', 'age': 18}, {'name': 'egon', 'age': 18}, {'name': 'oldboy', 'age': 84}, ] # set(stus_info) # 报错 l=[] for info in stus_info: if info not in l: l.append(info) # print(l) stus_info=l print(stus_info)