目錄
元組簡介
可變對象
字典簡介
遍歷字典5.集合
1. 元組簡介
元組基本介紹
元組表現(xiàn)形式tuple
元組是?個不可變序列(?般當(dāng)我們希望數(shù)據(jù)不改變時脓鹃,我們使?元組砸彬,其他情況下基本都?列表)
my_tuple = (1,2,3,4,5)
my_tuple[3] = 10 # TypeError: 'tuple' object does not support item assignment
- 使用()創(chuàng)建元素
- 元組不是空元組至少有?個 逗號(,)
my_tuple=0
print(my_tuple,type(my_tuple))
# 0 <class 'int'>
my_tuple=0,
print(my_tuple,type(my_tuple))
# (0,) <class 'tuple'>
- 當(dāng)元組不是空元組時括號可以省略
my_tuple = 10,20,30,40
print(my_tuple,type(my_tuple))
# (10, 20, 30, 40) <class 'tuple'>
元組解包
- 指將元組當(dāng)中的每?個元素都賦值給?個變量.
my_tuple = 10,20,30,40
a,b,c,d = my_tuple
print('a =',a)
print('b =',b)
print('c =',c)
print('d =',d)
- unpack的變量值要與元組元素數(shù)量相符艺玲。
my_tuple = 10,20,30,40
a,b,*c = my_tuple # ValueError: too many values to unpack (expected 2)
print('a =',a)
print('b =',b)
如果出現(xiàn)變量和元素沒有對等的情況下揭芍,我們可以在變量前面加個*這樣變量就會講獲取元組中所有剩余的元素以列表形式返回在變量前加
my_tuple = 10,20,30,40
a,b,*c = my_tuple
print('a =',a)
print('b =',b)
print('*c=',c)
# a = 10
# b = 20
# *c= [30, 40]
a,*b,c = my_tuple
print('a =',a)
print('b* =',b)
print('c=',c)
# a = 10
# b* = [20, 30]
# c= 40
列表中*也可發(fā)揮頂替所有值的作用
a,b,*c = [1,2,3,4,5,6,7,8,9]
# a,b,*c = 'python and java'
print('a =',a)
print('b =',b)
print('c =',c)
# c= 40
# a = 1
# b = 2
# c = [3, 4, 5, 6, 7, 8, 9]
a,b,*c = 'python and java'
print('a =',a)
print('b =',b)
print('c =',c)
# a = p
# b = y
# c = ['t', 'h', 'o', 'n', ' ', 'a', 'n', 'd', ' ', 'j', 'a', 'v', 'a']
2. 可變對象
Python中
不可變類型:數(shù)值類型(int和float)、字符串str会前、元組tuple。
可變類型:列表list匾竿、字典dict瓦宜、集合set。
可變對象中都保存了三個數(shù)據(jù):id(標(biāo)識)岭妖,type(類型)临庇,value(值)
-
可變對象指的就是我們可以對對象里面的value進(jìn)行改變
一般只有在為變量賦值時才是修改變量反璃,其余情況都是在修改對象(對象的值)。
# 列表是一個可變對象
a = [1,2,3]
a[0] = 10#(改對象)
# 這個操作時通過變量去修改對象的值
# 這種操作不會改變變量所指向的對象
a = [4,5,6]#(改變量)
# 這個操作在給變量重修賦值
# 這種操作會改變變量所指向的對象
-
改對象不改id(變量所指的對象)假夺,改變量會改id
a = [1,2,3]
print('修改前:',a,id(a))
#修改前: [1, 2, 3] 2914236901640
# # 通過索引修改列表
a[0] = 30
print('修改后:',a,id(a))
#修改后: [30, 2, 3] 2914236901640
# # 通過變量給列表重修賦值
a = [4,5,6]
print('修改后:',a,id(a))
# 改對象的值會影響所有指向該對象的變量
# 修改后: [4, 5, 6] 2914236901512
-
改對象的值淮蜈,會影響所有指向該對象的變量。
(修改對象時已卷,如果有其他變量指向該對象梧田,則修改也會在其他變量中體現(xiàn)。)
a = [1,2,3]
b = a
b[0] = 10
print('a',a,id(a))
print('b',b,id(b))
# a [10, 2, 3] 1703629236488
# b [10, 2, 3] 1703629236488
-
為一個變量重新賦值侧蘸,不會影響其他的變量
b = a
b = [10,2,3]
print('a',a,id(a))
print('b',b,id(b))
# a [1, 2, 3] 1703629236360
# b [10, 2, 3] 1703629236488
3. 字典簡介
字典的基本介紹
字典屬于?種新的數(shù)據(jù)結(jié)構(gòu)稱為映射(mapping)裁眯。
字典的作用和列表類似,都是用來存儲對象的容器讳癌。
列表存儲數(shù)據(jù)的性能好穿稳,但是查詢數(shù)據(jù)的性能差,字典正好與之相反晌坤。
在字典中每?個元素都有唯?的名字逢艘,通過這個唯?的名字可以找到指定的元素。
這個唯一的名字我們稱之為key 通過key可以快速查詢value 也可以稱之為值骤菠。
字典我們也稱之為鍵值對(key-value)結(jié)構(gòu)埋虹。
每個字典中都可以有多個鍵值對,而每?個鍵值對我們稱其為?項(item) 娩怎。
創(chuàng)建?個有數(shù)據(jù)的字典 語法 {key:value}。
字典的值可以是任意對象 字典的鍵可以是任意的不可變對象(int str bool tuple... )胰柑。
字典的鍵是不能重復(fù)的截亦,如果出現(xiàn)重復(fù)的后?的會替換前面的。
字典的使用
- dict()函數(shù)來創(chuàng)建字典
雙值子序列
雙值序列:序列(包括列表柬讨,元組崩瓤,字符串,字典etc.)中只有兩個值,('x',1),'ab',[5,6]
子序列:如果序列中元素也是序列踩官,那么我們就稱這個元素為子序列 [(4,5),(6,7)]
d = dict([('name','葫蘆娃'),('age',7)])
print(d,type(d)) #{'name': '葫蘆娃', 'age': 7} <class 'dict'>
- dict[key]獲取字典中的值
d = dict([('name','葫蘆娃'),('age',7)])
print(d['name']) #葫蘆娃
不要重復(fù)使用''
d = {'name':'葫蘆娃','age':7,'gender':'男'}
n = 'name'
print(d[n]) #葫蘆娃
print(d['n']) # KeyError: 'n'
- get(key[,default]) 根據(jù)鍵來獲取字典的值却桶。第?個參數(shù)可以指定一個默認(rèn)值,當(dāng)獲取不到值的時候會返回默認(rèn)值蔗牡。不會報錯
d = {'name':'葫蘆娃','age':7,'gender':'男'}
# 可以指定一個默認(rèn)值來作為第二個參數(shù) 這樣獲取不到值的時候回返回默認(rèn)值
print(d.get('python','該值不存在')) #該值不存在 默認(rèn)時None
- 修改&添加dict[key]
d = {'name':'葫蘆娃','age':7,'gender':'男'}
d['name'] = '鋼鐵俠' # 修改字典的key-value
d['phone'] = '15363347891' # 像字典中添加key-value
- 添加key-value颖系。dict.setdefault(key[,default])
如果key已經(jīng)存在到字典當(dāng)中,則返回key的值 不會對字典做任何操作
如果key不存在辩越,則像字典中添加這個Key 并設(shè)置value
d = {'name':'葫蘆娃','age':7,'gender':'男'}
d.setdefault('name','美國隊長')
r = d.setdefault('python','美國隊長')
print(r)
# 美國隊長
print(d)
# {'name': '葫蘆娃', 'age': 7, 'gender': '男', 'python': '美國隊長'}
- update() 將其他字典的key-value添加到當(dāng)前的字典當(dāng)中嘁扼,如果有重復(fù)的key,則后面的會替換到當(dāng)前的黔攒。
d = {'a':1,'b':2,'c':3}
d2 = {'d':4,'e':5,'f':6,'a':7}
d.update(d2)
print('d:',d)
# d: {'a': 7, 'b': 2, 'c': 3, 'd': 4, 'e': 5, 'f': 6}
- del 刪除字典中的key-value趁啸。
d={'a': 7, 'b': 2, 'c': 3, 'd': 4, 'e': 5, 'f': 6}
del d['a']
del d['b']
print('d:',d)
- popitem() 刪除字典最后的?個key-value 這個方法是有返回值的强缘。刪除之后它會將刪除的key-value作為返回值返回。
d={'a': 7, 'b': 2, 'c': 3, 'd': 4, 'e': 5, 'f': 6}
d.popitem()
print('d:',d)
# d: {'a': 7, 'b': 2, 'c': 3, 'd': 4, 'e': 5}
- pop(key[,default]) 根據(jù)key刪除?定中的value不傅。第二個參數(shù)可以指定?個默認(rèn)值旅掂,當(dāng)獲取不到值的時候會返回默認(rèn)值。
d={'c': 3, 'd': 4, 'e': 5, 'f': 6}
r = d.pop('d')
print(r) #4
r = d.pop('w','沒有這個key值') #沒有這個key值
print(d)
#{'c': 3, 'e': 5, 'f': 6}
- len()函數(shù)可以獲取字典中鍵值對的個數(shù)
d = dict([('name','葫蘆娃'),('age',7)])
print(len(d)) #2
- in 檢查字典中是否包含指定的鍵
d = dict([('name','葫蘆娃'),('age',7)])
print('name'in d) #True
- not in 檢查字典中是否不包含指定的鍵
copy()*只用=的話對象改了访娶,對應(yīng)變量也會該(目的-->原版不變商虐,復(fù)制版變,id不同)
- 淺復(fù)制字典震肮。如果字典里還有個字典是不會復(fù)制的
d2 = d.copy()
# 淺復(fù)制會簡單復(fù)制對象內(nèi)部的值,如果值也是個可變對象称龙,這個可變對象不會被復(fù)制
d = {'a':{'name':'蜘蛛俠','age':10},'b':2,'c':3}
d2 = d.copy()
d2['a']['name'] = '黑貓警長'
print('d =',d,id(d))
print('d2 =',d2,id(d2))
# d = {'a': {'name': '黑貓警長', 'age': 10}, 'b': 2, 'c': 3} 2381486551328
# d2 = {'a': {'name': '黑貓警長', 'age': 10}, 'b': 2, 'c': 3} 2381486497584
遍歷字典
- keys() 返回字典所有key
- values() 返回一個序列,序列中保存有字典的值
- items() 返回一個序列戳晌,返回字典中所有的項鲫尊,序列中包含有雙值(key和value)子序列。
d = {'name':'葫蘆娃','age':7,'gender':'男'}
print(d.keys())
# dict_keys(['name', 'age', 'gender'])
# 第一種
for k in d.keys():
print(d[k])
# 葫蘆娃
# 7
# 男
# 第二種
for v in d.values():
print(v)
# 葫蘆娃
# 7
# 男
# 第三種
# print(d.items())
for k,v in d.items():
print(k,v)
# name 葫蘆娃
# age 7
# gender 男
5. 集合
5.1 集合簡介
集合表現(xiàn)形式(set)和列表非常相似沦偎。
不同點:
- 集合只能儲存不可變對象()
s={[1,20,2,3,2,2,2,2,2,2]}#TypeError: unhashable type: 'list'
s=set([1,20,2,3,2,2,2,2,2,2]) #{1, 2, 3, 20} <class 'set'>
集合中儲存的對象是無序的(和輸入的順序不一樣)
集合中不能出現(xiàn)重復(fù)元素(用處:去重)
創(chuàng)造集合: set{}可將序列轉(zhuǎn)化為集合
s = set([1,2,3,4,2,2,3,1])
# {1, 2, 3, 4} <class 'set'>
# print(s,type(s))
s = set('python')
# {'h', 't', 'y', 'p', 'o', 'n'} <class 'set'>
-序列疫向、字典轉(zhuǎn)化為集合:set()
s={[1,20,2,3,2,2,2,2,2,2]}#TypeError: unhashable type: 'list'
s=set([1,20,2,3,2,2,2,2,2,2]) #{1, 2, 3, 20} <class 'set'>
-使用set()將字典-->集合,只包含keys
s=set({'a':1,'b':2}) #{'a', 'b'} <class 'set'>
- 集合不能用索引豪嚎,要用就強制轉(zhuǎn)換成list
s=set({'a':1,'b':2}) #{'a', 'b'} <class 'set'>
print(s['a'])#TypeError: 'set' object is not subscriptable
s={1,2,3}
print(s[0])#TypeError: 'set' object does not support indexing
- 集合中元素數(shù)量:len()
s={1,2,3}
print(len(s))#3
- 集合中添加元素: add()
s={1,2,3}
s.add(20)
print(s)
# {1, 2, 3, 20}
- 一個集合中元素添加到另一個集合中: update()
s={1,2,3}
r={4,5}
s.update(r)
print(s)
# {1, 2, 3, 4, 5}
- 隨機刪除一個元素搔驼,一般是最后一個元素: pop()
- 刪除指定元素:remove()
- 清空集合:clear()
5.2集合的運算
- 交集運算:&
s1={1,2,3,4}
s2={2,4,5,6,7}
s1&s2
print(s1&s2) #{2, 4}
- 并集運算:|
s1={1,2,3,4}
s2={2,4,5,6,7}
print(s1|s2) #{1, 2, 3, 4, 5, 6, 7}
- 差集運算: - (只在第一個集合中出現(xiàn),不在第二個集合中出現(xiàn)的元素侈询。)
s1={1,2,3,4}
s2={2,4,5,6,7}
print(s1-s2) #{1, 3}
- 亦或集:^(只在第一或第二個集合中出現(xiàn)的元素舌涨。)
s1={1,2,3,4}
s2={2,4,5,6,7}
print(s1^s2) #{1, 3, 5, 6, 7}
- 檢查一個集合是否是另一個集合的子集<=
a={1,2,3,4}
b={1,2,3,4,5}
result= a<=b
print(result)
# True
# a集合時b集合的子集,b集合是a集合的超集
- 檢查一個集合是否是另一個集合的真子集<
- 檢查一個集合是否是另一個集合的超集>=
- 檢查一個集合是否是另一個集合的真超集>