day07 元组类型 字典类型 集合

元组:元组就是一个不可变的列表

1、用途:当我们需要记录多个同种属性的值,并且只有读的需求,没有改的需求,应该用元组。

2、定义方式:在()内用逗号分隔开多个任意类型的元素

t=(‘egon’)#注意:当元组内只有一个元素时,必须加逗号,t=tuple(('egon)),

print(t,type(t))

print(t[0])

数据类型转换:

t=tuple('hello')

print(t,type(t))

常用操作+内置方法

3.1优先掌握的操作

1、按索引取值(正向取+反向取 ):只能取

t=(‘a’,'b','c')

t[0]='A'

2 切片,(顾头不顾尾,步长)

t=('a','b','c')

print=(t[0:2])

3长度

print(len(t))

4成员运算in 和 not in

t=('a','b','c','d')

print('a' in t)

5循环

t=('a','b','c','d')

for item in t:

print(item)

3.2需要掌握的操作

t=('a','b','c','d',(1,2,3))

print(t.count('b')数B的数量

print(t.index('b',2,4)在2和4之间查找‘b’的索引

总结:

可以存多个值

有序

不可变(1、可变:值变,id不变。可变==不可hash 2、不可变:值变,id就变。不可变==可hash)

0    1             2

t=(1,'a',['m'n])

print(id(t[0]),id(t[1]),id(t[2]))

t[2][0]='m'

print(id(t[0]),id(t[1]),id(t[2]))

t[2]的内存地址没有改变所以元组的内存地址不变=========================================================================

集合类型

一:引入
# pythons=['李铁蛋','张全蛋','王铜蛋','赵银蛋','oldboy','艾利克斯']
# linuxs=['kevin','egon','tank','艾利克斯','王铜蛋']
#
# l=[]
#
# for item in pythons:
# if item in linuxs:
# l.append(item)
#
# print(l)
二、集合(set)
1、用途:
1.1做关系运算
1.2去重
2、定义方式:在{}内用逗号分隔开多个元素,多个元素必须满足以下条件
2.1每个元素必须是不可变类型
2.2集合内元素不能重复
2.3集合无序
s={1,1.1,'aaa',1,1,1,1}
print(s,type(s))
注意点:
d={}#默认定义为字典
print(type(d))
s=set()
print(s,type(s))

数据类型转换

s=set('hello')

print(s)

3、常用操作+内置的方法

pythons={'李铁蛋’,‘张全蛋’,‘王银蛋’,‘oldboy’,‘艾利克斯’

linuxs={'kevin','egon','tank','艾利克斯’,‘王铜蛋 ’}

#

求刚报名pythons课又报名linuxs课时的学员:交集

res=pythons&linuxs

print(res)

res1=pythons.intersection(linuxs)

print(res1)

求所有的学员姓名:并集

res=pythons-linuxs

print(res)

print(pythons.difference(linuxs))

res=linuxs-pythons

print(res)

求没有同时报名两门课程的学员:对称差集

res=pythons^linuxs

print(res)

print(pythons.symmertrip_difference(linuxs))

父集/子集;

包含与被包含关系:

 

s1={1,2,3}

s2={3,1,2}

print(s1==s2)

s1={1,2,3}

s2={3,1,2}

print(s1>=s2)

print(s1.issuperset(s2))

print(s2<=s1)

print(s2.issuperset(s))

长度len

print(3 in s1)

成员运算in和not in

掌握的操作

1,s1={'a','b','cc','2','3'}

print(id(s1))

2,s1.update({3,4,5})

print(s1,id(s1))

3,s1.add(4)

print(s1)

4,res=s1.pop()

print(res)

5,res=s1.remove('b')

print(s1)

print(res)

6,s1={1,2,3}

s2={1,2,3}

s1.difference_update(s2)#s1=s1-s2

print(s1)

s1.intersection_update(s2)#s1=s1&s2

print(s1)

s1.symmetric_difference_update(s2)#s1=s1^s2

print(s1)

'''

s1={1,2,3}

s1.remove(4)

s1.discard(3)

print(res)#None

'''

'''s1={1,2,3}

s2={4,5,6}

print (s1.isdisjoint(s2))

'''

类型总结

1,可以存多个值

2,无序

3,set可变类型

4,去重

name=['egon','egon','keven','keven','alex','alex']

方法:

l=[]

for name in names:

    if name not in l ;

        l.append(name)

print(l)

2,如果去重的对象都是不可变类型并且不要求结果跟原来的顺序一致,那么就用set解决

# res=set(names)
# # print(res)
# l=list(res)
# print(l) info=[
{'name':'egon','age':18,'sex':'male'},
{'name':'alex','age':73,'sex':'male'},
{'name':'egon','age':20,'sex':'female'},
{'name':'egon','age':18,'sex':'male'},
{'name':'egon','age':18,'sex':'male'},
]
l=[]
for dic in info:
if dic not in l:
l.append(dic)
print(l)

字典类型:

# ======================================基本使用======================================

1、用途:记录多个不同属性的值

2、定义方式:在{}内用逗号分隔开多个元素,每一个元素都是key:value的形式,其中value可以是任意类型,Key必须是不可变类型(通常应该str类型)

dic={1:'aaa',1.3:'bbc',(1,2,3):'ccc','xxx':'ddd'}#dic=dict()

dic={'x':1'x':'2','x':3}

print(dic)

数据类型转换:dict

li=(['name','egon'],('age',18),('gender','male')

dic={}

for k,v in li:

dic[k]=v

dic=dict(li)

dic=dict(x=1,y=2,z=3)

print(dic)

3\常用操作+内置的方法

3.1、优先掌握的操作

1、按key存取值:可存可取

dic={'name':'egon','age':18,'gender':'male'}

print(dic['name'])

print(id(dic))

dic['name']=EGON

print(dic,id(dic))

dic['height']=1.81#/如果key不存在新增一组key:value

print(dic)

l=['a']

l[1]='b'

2、长度len

dic={'name':'egon','age':18,'gender':'male'}

print(len(dic))

3、成员运算in 和not in

dic={'name':'egon','age':18,'gender':'male'}

print('name' in dic)

4、删除

dic={'name':'egon','age'=18,'gender':'male'}

del dic['name']  删除的通用操作,拿到的返回值为None

print(dic)

t=dic.popitem()  无序删除,可以拿到返回值

print(t,type(t))

v=dic.pop('name') 可以指定删除数据,根据key来删除

print(v)

5、键keys(),值value(),键值对items()

dic={'name':'egon','age':18,'gender':'male'}

keys=dic.keys()

print=(keys)

取到的值:['gender','name','age']

values=dic.values()

print(values)

取到的值:['male','eon',18]

items=dic.items()

print(items)

取到的值:[('gender','male'),('age',18),('name','egon')]

print(list(keys))

print(list(values))

print(list(items))

5、循环

for k in dic.keys():

print(k)

for k in dic:

print(k)

for k,v in dic.items():

print(k,v)

for v in dic.values():

print(v)

7、get 取值:值存在,则取值,值不存在,则返回None

dic={'name':'egon','age':18,'gender':'male'}

if 'xxx' in dic:

print(dic['xxx'])

else:

print(None)

v=dic.get('age')

print(v)

3.2需要掌握的操作

dic.fromkeys()   给一个列表附上空值。

li=['name','age','gender']

dic={}

for k in li :

dic[k]=None

print(dic)

dic={}.fromkeys(li,None)

print(dic)

dic.update() 更新功能:如果原字典存在则替换,如果原字典不存在则新增

old_dic={'name':'egon','age':18,'gender':'male'}

new_dic={'x'=1,'name':'EGON'}

old_dic.update.(new_dic)

print(old_dic)

dic.setdefault(k,v):执行完毕后是为了保证字典中必须有这么一个k

dic={'name':'egon','age':18,‘gender’:'male'}

v=dic.setdefault('helght',1.81)字典中没有‘height’这个键,则新增

print(dic)

print(v)

v=dic.setdefault('name','EGON')字典中有‘name’这个键,则新增

print(dic)

print(v)

v=dic.setdefault('name','EGON')#字典中有‘name’这个键,不修改字典

print(dic)

print(v) 拿到的是字典里原有的‘egon’

#setdefault 的原理分析:

k='name'

v='EGON'

if k not in dic:

dic[k]=v

print(dic)

======================================该类型总结====================================

存多个值

无序

可变(1、可变:值变,id不变。可变==不可hash 2、不可变:值变,ID就变,不可变==可hash)

上一篇:异常检测算法:Isolation Forest


下一篇:Jena解析rdf、nt、ttl格式数据