元组:用()包含起来并用逗号分隔开的一系列数据的集合。
1、常用操作(索引、切片、元组化、成员运算、遍历、长度)
number=(1,2,3,2,1)
#元组的索引
print(number[0]) #返回第一个值》1
print(number[-1]) #返回最后一个值》1
#元组切片
print(number[0:5:1]) #返回一个元组。元组包括:第一个到第(5-1)个值,步长为1》(1, 2, 3, 2, 1)
print(number[-1:-5:-1])#反向取值,组成一个新元组
#元组的遍历,同列表等,采用for
names=["alex","duke","fox","duke","fox","fox"]
name_count={}
for name in names:
name_count.setdefault(name,names.count(name))
print(name_count)
#成员运算,(逻辑运算) in ,not in
number=("duke","ergou","erick","egon")
print("erick" in number) #True
print("erick" not in number) #False
#初始化元组
#tuple(可迭代类型),返回一个元组,tuple()定义了一个空元组
tuple1=tuple("abcud as")
print(tuple1)
tuple1=tuple([1,22,3,4,5])
print(tuple1)
tuple1=tuple((1,2,3,4,5))
print(tuple1)
tuple1=tuple({1:1,2:2,3:3})
print(tuple1)
tuple1=tuple({1,2,3,4,5})
print(tuple1)
"""输出结果:
('a', 'b', 'c', 'u', 'd', ' ', 'a', 's')
(1, 22, 3, 4, 5)
(1, 2, 3, 4, 5)
(1, 2, 3)
(1, 2, 3, 4, 5)
"""
#定义知有一个元素的元组
tuple1=tuple()
tuple2=()
print(type(tuple1),type(tuple2))
tuple1=(2,)
tuple2=(2)
print(type(tuple1),type(tuple2))
"""输出结果:
"""
2、内置函数 index,count
index():返回第一个索引值,若不存在就报错
count():计算某一元素在元组中出现的次数
"""
index:查找,并返回该值所在可迭代类型中的位置,若未找到值,则报错
使用方法:T.index(value, [start, [stop]])
"""
print(number.index(2))
print(number.index(2,2))
number=("duke","ergou","erick","egon")
number.count("duke")
字典:在{}中,用逗号隔开的“key:value”键值对的集合。
一、常用操作
name_age={"alex":18,"liric":13,"duke":20,"alex":19}
name_age["alex"] #>>>>= 18
name_age["duke"] #>>>>= 20
name_age={"alex":18,"liric":13,"duke":20,"alex":19}
name_age["alex"]=25 #>>>={'alex': 25, 'liric': 13, 'duke': 20}
print(name_age)
name_age["zhang dadan"]=21
print(name_age) #>>>={'alex': 25, 'liric': 13, 'duke': 20, 'zhang dadan': 21}
name_age={"alex":18,"liric":13,"duke":20,"alex":19}
print(name_age.keys()) #>===dict_keys(['alex', 'liric', 'duke']) 不会占用内存
print(name_age.values()) #>===dict_values([19, 13, 20])
print(name_age.items()) #>===dict_items([('alex', 19), ('liric', 13), ('duke', 20)])
"""字典循环"""
name_age={"alex":18,"liric":13,"duke":20}
for k in name_age.keys():
print(k)
for k in name_age:
print((k))
for v in name_age.values():
print(v)
for item in name_age.items():
k,v=item
print(k,v)
for k,v in name_age.items():
print(k,v)
"""dict()初始化:
(1):dict():创建一个空字典
(2):dict(mapping):从具有映射关系(目前所学:字典)(key,value)初始化一个新字典
(3):dict(iterable):从一个可迭代类型初始化一个新字典,可迭代类型(key,value)
(4):dict(**args):从key=vlaue中初始化一个新字典"""
dict1=dict()
print(dict1)
dict1=dict({"able":2,"ergou":123})
print(dict1)
# 集合、列表、元组的随意组合,内层每一个包含两个值,第一个值不能为可变类型
dict1=dict((["able",16],["ergou",123]))
print(dict1)
#key值会自动转为字符串
dict1=dict(able=18,ergou=18)
print(dict1)
"""输出结果:
{}
{'able': 2, 'ergou': 123}
{'able': 16, 'ergou': 123}
{'able': 18, 'ergou': 18}
"""
"""
get(),获取K值对应的Value值,若K存在,则返回value,否则什么也不做
"""
name_age={"erick":18,
"duke":21,
"ergou":22
}
print(name_age.get('erick')) #>=18
print(name_age.get('ergu')) #>=None
name_age={"erick":18,
"duke":21,
"ergou":22
}
"""
setdefault(self, k, d=None):
使用方法:D.setdefault(k[,d])
-> if k in D.keys: if d: D[K]=d return d else return D[k]
if k not in D.keys: if d: D[k]=d return D[k] else: D[k]=None retuen None
"""
print(name_age.setdefault("duke",21))
print(name_age)
print(name_age.setdefault("lichengyu"))
print(name_age)
"""输出结果:
21
{'erick': 18, 'duke': 21, 'ergou': 22}
None
{'erick': 18, 'duke': 21, 'ergou': 22, 'lichengyu': None}
"""
"""
update():更新一个D(字典),从一个字典/可迭代类型E和F中
使用方法:D.update([E, ]**F)
**F:1、若E存在且具有.keys的方法,则D(K)=F(K),则E是一个字典
2、若E存在且不具有.keys的方法,for k,v in E D[K]=V,则E为一个可迭代类型,且E的每一次循环的元素中都包含两个元素
在这两种情况下,这都是:对于F:d[k]=f[k]中的k
"""
# 0 默认E为空,则采用**模式将其转换字典进行更新
alpha.update(x=2,z=3)
print(alpha)
# 1 若E为一个字典
alpha.update({"x":5,"q":6},h=6,g=8)
print(alpha)
# 2 若E存在且不具有.keys的方法,for k,v in E D[K]=V
alpha.update((("x",1),("g","h")))
print(alpha)
alpha.update([["x",3],("g","qh")])
print(alpha)
"""输出结果:
{'x': 2, 'y': 2, 'z': 3}
{'x': 5, 'y': 2, 'z': 3, 'q': 6, 'h': 6, 'g': 8}
{'x': 1, 'y': 2, 'z': 3, 'q': 6, 'h': 6, 'g': 'h'}
{'x': 3, 'y': 2, 'z': 3, 'q': 6, 'h': 6, 'g': 'qh'}
"""
#pop():任意删除一对键值对,并且后续依旧可以使用该值
f=name_age.pop("alex")
print(id(name_age)) #>>==2017606815888
print(f,name_age) #>>==19 {'duke': 20}
#popitem ():任意删除字典中的一对键值对,并让他们组成元组
name_age={"alex":18,"liric":13,"duke":20,"alex":19}
x=name_age.popitem()
print(x,name_age) #>>==('duke', 20) {'alex': 19, 'liric': 13}
# del 删除一对键值对,而且不可再用
del name_age["liric"]
print(name_age) #>>{'alex': 19, 'duke': 20}
集合:是由{}存储的一系列逗号,分隔开的值
集合:是无需的
集合:关系运算和去重
"""
集合:用{}包含起来的,并且用逗号分隔开的一系列不可变类型的值
遵循三个原则:1、集合内元素是无序,不能索引
2、集合内元素必须是不可变类型(数字,字符串,元组)
3、集合内没有重复元素
1、集合可以存多个值
2、集合是可变类型,不可被hash,不能作为字典的key
3、集合是无序的
作用:关系运算
去重:去重的对象中不能包括可变类型
去重后的结果是无序的
"""
#一、关系运算
pythons={'alex','egon','yuanhao','wupeiqi','gangdan','biubiu'}
linuxs={'wupeiqi','oldboy','gangdan'}
#1 求并集
#1.1 符号方法
print(pythons | linuxs)
#1.2命令方法
print(pythons.union(linuxs))
"""输出结果:
{'egon', 'oldboy', 'biubiu', 'gangdan', 'alex', 'wupeiqi', 'yuanhao'}
{'egon', 'oldboy', 'biubiu', 'gangdan', 'alex', 'wupeiqi', 'yuanhao'}
"""
#2.求交集
#2.1符号方法
print(pythons & linuxs)
#2.2 用命令方法
# intersection:横断,横切;交叉,相交;交叉点,交叉线;[数]交集
print(pythons.intersection(linuxs))
"""输出结果:
{'gangdan', 'wupeiqi'}
{'gangdan', 'wupeiqi'}
"""
#3 求差集(求差级对顺序有关系,是前者求对于后者的差集)
#3.1 符号法
print(pythons - linuxs)
print(linuxs - pythons)
#3.2 用命令
#difference:差别,差异;[数]差数,差额;意见分歧;特色
print(pythons.difference(linuxs))
print(linuxs.difference(pythons))
"""输出结果:
{'biubiu', 'yuanhao', 'egon', 'alex'}
{'oldboy'}
{'biubiu', 'yuanhao', 'egon', 'alex'}
{'oldboy'}
"""
#4对称差集(和顺序无关)
#4.1 符号
print(pythons ^ linuxs)
#4.2 用命令
print(pythons.symmetric_difference(linuxs))
"""输出结果:
{'biubiu', 'alex', 'yuanhao', 'egon', 'oldboy'}
{'biubiu', 'alex', 'yuanhao', 'egon', 'oldboy'}
"""
#5父集(即属于 父集>子集 )返回结果False\True
#5.1 符号 >
set1={1,2,3,4,5}
set2={1,2,3}
print(set1 > set2)
print(set1={32, 2, 3, 4, 5, 67, 40, 23, 89}
"""
pop():移除并且任意返回一个集合元素,若集合是空集,则会报错
"""
nuber=set1.pop()
print(nuber,set1,sep=" ") #>=2 {2, 3, 4, 5, 67, 40, 23, 89}
"""
remove(element):若集合中存在element,则移除该元素;若集合不存在element,则会报错
"""
set1.remove(3)
print(set1) #>={2, 4, 5, 67, 40, 23, 89}
#增加一个指定素
set1.add(6)
print(set1) #>={2, 4, 5, 67, 6, 40, 23, 89}
set2={1,9,8,34,5,2,4,5}
#用set1与set2的差集去更新set1
print(set1.difference(set2)) #>={2, 4, 5, 67, 40, 23, 89}
set1.difference_update(set2)
print(set1) #>={2, 4, 5, 67, 40, 23, 89}
#用set1与set2的对称差集去更新set1
print(set1.symmetric_difference(set2)) #>={1, 34, 2, 4, 5, 67, 6, 40, 8, 9, 23, 89}
set1.symmetric_difference_update(set2)
print(set1) #>={1, 34, 2, 4, 5, 67, 6, 40, 8, 9, 23, 89}
#用set1与set2的交集去更新set1
print(set1.intersection(set2)) #>={67, 6, 40, 23, 89}
set1.intersection_update(set2)
print(set1) #>={67, 6, 40, 23, 89}
"""
set1.isdisjoint(set2):如果两个集合的交集是空集的话,则返回True,否则返回False
"""
set1={1,2,3,4,5}
set2={56,7,8,9,10}
print(set1.isdisjoint(set2)) #>=True
set2={1,2,3}
print(set1.isdisjoint(set2)) #>=False
#四,定义一个空集合
set1={} #这种定义方式错误
print(type(set1)) #>=
set1=set({})
print(type(set1)) #>=
"""D.add(element):增加一个元素到集合D中,若该元素已存在于D中,也没有什么影响"""
set1.add("5")