一.元祖类型  (tuple)

1.什么是元祖?

用途:用于存放多个值,当存放的多个值只有读的需求没有改变的需求时,用元祖最合适.

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

t=(1,3,1,'aaa',(1,2,3),['a','b'])   #= tuple

res=tuple('hello')

res=tuple({'x':1,'y':2})

print(res)

 

2.常用的操作内置方法.

优先掌握的操作:

1.按索引的方式取值,(正向取,反向取都可以,但是只能去不能存.)

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

t[0]=111

 

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

t=('h','e','l','l','o')

res=t[1:3]

print(res)

print(t)

 

3.长度

t=('h','e','l','l','o')

print(len(t))

 

4.成员运算 in 和 not in

t=('h','e','l','l','o')

print('h' in t)

 

5.循环

t=('h','e','l','l','o')

for item in t:

  print(item)

 

该类型总结.

可以存多个值,是有序的, 是不可变类型.(但是元祖里面有列表的情况下,可以改变列表.)

t=(1,'a',['x','y','z'])

print(id(t[2]))

print(id(t))

t[2][0]='X'

print(t)

print(id(t))

print(id(t[2]))

 

需要掌握的方法

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

print(t.index('a'))

t.index('xxx')

print(t.count('a'))

可以运算一下有几个a

 

元祖符号

name=input('>>:').strip()

print(('my name is %s'%name).center(50,'*'))

center 代表可以在一行代码里补充入多少个字符,数字是整个长度有多少

 

二.字典类型  (dict)

用途:用来存多个(不同种类的值)

1.定义方式:在{}内用逗号分隔开多个Key:value的元素,其中value可以是任意的数据类型,而Key的功能通常是用来描述value的,

所以Key通常是字符串类型,但其实Key必须是不可变的类型(int\float\str\tuple)

d={0:'x',1.3:'y','K1':'z',(1,2,3):'aaa'}  #d=dict(...)

print(d[(1,2,3)])

d1

{[1,2,3]:'aaaa'}

d=dict([('K1',1),('K2',2),('K3',3)])

print(d)

 

l=[('k1',1),('k2',2),('k3',3)]
d={}
for t in l: #t=('k1',1)
k,v=t
print(k,v)
d[k]=v
print(d)

d=dict(l)
print(d)


d=dict(x=1,y=2,z=3)
print(d)

2.常用的操作+内置的方法

优先掌握的操作:

1.按Key存取值,可存可取

d={'x':1}
print(d['x'])
print(id(d))
d['x']=1111
print(d)
print(id(d))
d['y']=2222
print(d)


3.长度
d={'x':1,'y':2,'z':3}
print(len(d)) (可以查看字典的长度)


4.成员运算in和not in
d={'x':1,'y':2,'z':3}
print(1 in d) True
print('x ' in d) True


5.删除
d={'x':1,'y':2,'z':3}
del d['y']
print(d) (del直接删除)


d={'x':1,'y':2,'z':3}

res=d.pop('y')

print(d)
print(res)   (pop可以在后面按索引删除)


6.键Keys(),值value(),键值一起是items()
d={'name':'egon','age':18,'sex':'male','hobbies':[1,2,3]}
print(d.keys())
print(list(d.keys()))

print(d.values())
print(list(d.values()))
print(d.items())
print(list(d.items()))

7.循环的使用
d={'name':'egon','age':18,'sex':'male','hobbies':[1,2,3]}
for k in d.keys():
print(k)
for k in d:
print(k)

for v in d.values():
print(v)

for k,v in d.items(): #k,v=('name', 'egon')
print(k,v)

该类型的总结:
存在多个值, 是无序的 可变的.

需要掌握的操作.
get的方法
d={'name':'egon','age':18,'sex':'male','hobbies':[1,2,3]}
v=d.get('namexxxxxxx')
print(v)
输出结果为: none

get可以随意的取值,还不会报错.


update的方法
d={'name':'egon','age':18,'sex':'male','hobbies':[1,2,3]}
d.update({'x':1,'name':"EGON"})
print(d)

update更新的意思,如果没有想要更新的item就可以直接加进去,如果有了.就更新.



fromkeys:需求是快速的新造出一个字典,value的初始值为None.而Key是来自于一个列表
keys=['name','age','sex']
d={}.fromkeys(keys,None)
print(d)


setdefault 在Key存在的情况下不会修改值,会返回原值 在Key不存在的情况下会新增值,会返回新增的值.
d={"x":1,"y":2}
res=d.setdefault('x',11111)
print(d)
print(res)


d={"x":1,"y":2}
res=d.setdefault('z',11111)
print(d)
print(res)



三.集合类型 (set)

1.什么是集合
在{}内用逗号分隔开多个值,集合的特点:
1.每个值必须是不可变类型.
2.集合是无序的.
3.集合内元素不能重复

2.为何要用集合:
1.用作关系运算.
2.去重

3.如何去用集合

集合的第一大用途,关系运算!
pythons={'egon','张铁蛋','李铜蛋','赵银弹','王金蛋','艾里克斯'}
linuxs={'欧德博爱','李铜蛋','艾里克斯','lsb','ysb','wsb'}
1 求同时报名两门课程的学生姓名:交集
print(pythons & linuxs) (简单的逻辑运算符号)
print(pythons.intersection(linuxs)) (属于内置的方法不建议用)


2.求报名老男孩学校课程的所有学生姓名:并集
print(pythons | linuxs) (同上)
print(pythons.union(linuxs))


3 求只报名python课程的学生姓名: 差集
print(pythons - linuxs) (把一起上了两门课程的同学排除)
print(pythons.difference(linuxs))

4 求没有同时报名两门课程的学生姓名: 对称差集
print((pythons - linuxs) | (linuxs - pythons))
print(pythons ^ linuxs) (明显第二个字符更简单)
print(pythons.symmetric_difference(linuxs))

5 父子集:指的是一种包含与被包含的关系
s1={1,2,3}
s2={1,2}
print(s1 >= s2)
print(s1.issuperset(s2))
print(s2.issubset(s1))
情况一:
print(s1 > s2) #>号代表s1是包含s2的,称之为s1为s2的父集
print(s2 < s1)

情况二:
s1={1,2,3}
s2={1,2,3}
print(s1 == s2) #s1如果等于s2,也可以称为s1是s2的父集

综上:
s1 >= s2 就可以称为s1是s2的父集 两个值相同的集合,可以互为父集,也互为子集.看自己定义

s3={1,2,3}
s4={3,2,1}
print(s3 == s4) (一样的结果,互为父集.互为子集)



2.集合的第二大用途:去重 
集合去重的局限性:
1.会打乱原值的顺序
2.只能针对不可变的值去重

stus=['egon','lxx','lxx','alex','alex','yxx']
new_l=list(set(stus))
print(new_l)

old_l=[1,[1,2],[1,2]]
set(old_l)
(不可hash的类型不可以被去重)


l=[
{'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'},
]
new_l=[]
for dic in l:
if dic not in new_l:
new_l.append(dic)
print(new_l)



需要掌握的操作:
s1={1,2,3}
s1.update({3,4,5})
print(s1)
print(s1.pop())
print(s1)

pop在集合里不能索引删除,

s1.remove(2)
print(s1)

remove可以在集合里随便删除,后面加上想删除的字符.


s1={1,2,3}
print(id(s1))
s1.add(4)
print(s1)
print(id(s1))

add可以随便的添加字符,但是有了同样字符的话就不添加,没有影响.

s1={1,2,3}
s1.discard(4)

print(s1)

discard可以随意的删除字符,没有这个字符也没影响.


s1={1,2,3}
s2={4,5}
print(s1.isdisjoint(s2))

isdisjoinnt:判断两个两个集合是否完全不相交.

总结:
集合存在多个值,是无序的.属于可变类型.


























































































 

 

posted on 2018-09-18 21:28  海贼王。  阅读(192)  评论(0编辑  收藏  举报