<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
序列是基礎類別型別,序列擴充套件型別包括:字串、元組和列表
序列都可以進行的操作包括索引,切片,加,乘,檢查成員。
此外,Python已經內建確定序列的長度以及確定最大和最小的元素的方法。
列表:列表是序列型別的一種擴充套件,十分常用
hobby_list = [hobby, 'run', 'girl'] print(id(hobby_list)) # 4558605960 print(type(hobby_list)) # print(hobby_list) # ['read', 'run', 'girl']
如果想初始化個長度為10的列表
list_empty = [None]*10 print(list_empty) # [None, None, None, None, None, None, None, None, None, None]
使用range()函數來建立一個列表:
hobby_list = list(range(5)) # [0, 1, 2, 3, 4]
hobby_list = ['read', 'run',['girl_name', 18, 'shanghai'] ] print(hobby_list[2][1])# 取出girl的年齡 18
python 建立二維列表,將需要的引數寫入 cols 和 rows 即可
list_2d = [[0 for i in range(5)] for i in range(5)] list_2d[0].append(3) list_2d[0].append(5) list_2d[2].append(7) print(list_2d) # [[0, 0, 0, 0, 0, 3, 5], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 7], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0]]
以下範例將3X4的矩陣列表轉換為4X3列表:
# 以下範例展示了3X4的矩陣列表: matrix = [ [1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12], ] # 以下範例將3X4的矩陣列表轉換為4X3列表: transposed=[[row[i] for row in matrix] for i in range(4)] print(transposed) # [[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]] # 以下範例也可以使用以下方法來實現: transposed = [] for i in range(4): transposed.append([row[i] for row in matrix]) print(transposed) # [[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]
索引序號從0開始。
hobby_list = ['read', 'run', 'girl'] # 索引序號 0 1 2 print(hobby_list[1])# 取出第二個愛好 <code>run
可以對列表的資料項進行修改或更新,你也可以使用append()方法來新增列表項,
hobby_list = ['read', 'run', 'girl'] hobby_list[0] = 'write'
列表方法使得列表可以很方便的作為一個堆疊來使用。堆疊作為特定的資料結構,最先進入的元素最後一個被釋放(後進先出)。
用 append() 方法可以把一個元素新增到堆疊頂。用不指定索引的 pop() 方法可以把一個元素從堆疊頂釋放出來。
例如:
stack = [3, 4, 5] stack.append(6) stack.append(7) print(stack) # [3, 4, 5, 6, 7] print(stack.pop()) # 7 print(stack) # [3, 4, 5, 6] print(stack.pop()) # 6 print(stack.pop()) # 5 print(stack) # [3, 4]
列表推導式提供了從序列建立列表的簡單途徑。通常應用程式將一些操作應用於某個序列的每個元素,用其獲得的結果作為生成新列表的元素,或者根據確定的判定條件建立子序列。
每個列表推導式都在 for 之後跟一個表示式,然後有零到多個 for 或 if 子句。
返回結果是一個根據表達從其後的 for 和 if 上下文環境中生成出來的列表。如果希望表示式推匯出一個元組,就必須使用括號。
舉例:
print([i for i in range(10)] ) # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] print([i ** 2 for i in range(10)]) # [0, 1, 4, 9, 16, 25, 36, 49, 64, 81] print([0 for i in range(5)]) #[0, 0, 0, 0, 0] name_list = ['nick', 'sean', 'jason', 'tank'] for n in [name if name == 'nick' else name + '_a' for name in name_list] : print(n) # 'nick', 'sean_a', 'jason_a', 'tank_a' li = [1, 2, 3, 4, 5, 6, 7, 8, 9] print( [x ** 2 for x in li]) # [1, 4, 9, 16, 25, 36, 49, 64, 81] print( [x ** 2 for x in li if x > 5]) # [36, 49, 64, 81] print(dict([(x, x * 10) for x in li])) # {1: 10, 2: 20, 3: 30, 4: 40, 5: 50, 6: 60, 7: 70, 8: 80, 9: 90} #生成字典 vec1 = [2, 4, 6] vec2 = [4, 3, -9] sq = [vec2[i] + vec2[i] for i in range(len(vec))] # 實現列表相加 print(sq) # [6, 7, -3] testList = [1, 2, 3, 4] def mul2(x): return x * 2 print([mul2(i) for i in testList]) #使用複雜表示式或巢狀函數: # [2, 4, 6, 8]
語句之間是巢狀關係。
左邊第二個語句是最外層,依次往右進一層,左邊第一條語句是最後一層。
[x*y for x in range(1,5) if x > 2 for y in range(1,4) if y < 3]
他的執行順序是:
for x in range(1,5) if x > 2 for y in range(1,4) if y < 3 x*y
範例
print( [ (x, y) for x in range(10) if x % 2 if x > 3 for y in range(10) if y > 7 if y != 8]) #生成元組 # [(5, 9), (7, 9), (9, 9)] print([x * y for x in [1, 2, 3] for y in [1, 2, 3]]) # [1, 2, 3, 2, 4, 6, 3, 6, 9]
ls1 = ['python', 123] ls2 = ['java', 456] print(ls1 * 2); # ['python', 123, 'python', 123] 將列表複製n次。 print(ls1 + ls2); # ['python', 123, 'java', 456] 連線兩個列表 name_list = ['nick', 'jason', 'tank', 'sean'] del name_list[2] # 刪除索引2位置後的元素 print(name_list) # ['nick', 'jason', 'sean'] del name_list[2:4] # 從列表中刪除切片 ,刪除第i-j位置的元素 print(name_list) # ['nick', 'jason'] del name_list[:] #清空整個列表 print(name_list) # [] del a # 用 del 刪除實體變數: name_list = ['nick', 'jason', 'tank', 'sean'] print('tank sb' in name_list) # 成員運算:in; False print('nick handsome' not in name_list) # 成員運算:in;True name_list = ['nick', 'jason', 'tank', 'sean'] for name in name_list: # for迴圈 print(name) a = ['Google', 'Baidu', 'Runoob', 'Taobao', 'QQ'] for i in range(len(a)): # 結合range()和len()函數以遍歷一個序列的索引 print(i, a[i]) # 0 Google 1 Baidu 2 Runoob 3 Taobao 4 QQ name_list = ['nick', 'jason', 'tank', 'sean'] print(name_list[0:3:2] ) # 切片 ['nick', 'tank']
舉例:有如下列表,列表元素為不可hash型別,去重,得到新列表,且新列表一定要保持列表原來的順序
stu_info_list = [ {'name': 'nick', 'age': 19, 'sex': 'male'}, {'name': 'egon', 'age': 18, 'sex': 'male'}, {'name': 'tank', 'age': 20, 'sex': 'female'}, {'name': 'tank', 'age': 20, 'sex': 'female'}, {'name': 'egon', 'age': 18, 'sex': 'male'}, ] new_stu_info_list = [] for stu_info in stu_info_list: if stu_info not in new_stu_info_list: new_stu_info_list.append(stu_info) for new_stu_info in new_stu_info_list: print(new_stu_info)
name_list = ['nick', 'jason', 'tank', 'sean'] print(len(name_list)) # 4 列表元素個數:len; print(min(name_list)) # jason 返回序列s的最小元素; print(max(name_list)) # tank 返回序列s的最大元素 name_list = ['nick', 'jason', 'tank', 'sean'] name_list.insert(1, 'handsome') # insert(i,x):在列表的第i位置增加元素x print(name_list) # ['nick', 'handsome', 'jason', 'tank', 'sean'] name_list = ['nick', 'jason', 'tank', 'sean'] print(name_list.remove('nick')) # remove(x):將列表ls中出現的第一個元素x刪除 ,None ; print(name_list) # ['jason', 'tank', 'sean'] name_list = ['nick', 'jason', 'tank', 'sean'] print(name_list.count('nick')) # 1 ;統計某個元素在列表中出現的次數 name_list = ['nick', 'jason', 'tank', 'sean'] print(name_list.index('nick')) # 0;返回元素所在列表中的索引 name_list = ['nick', 'jason', 'tank', 'sean'] name_list.clear() # 刪除列表中所有元素 print(name_list) # [] name_list = ['nick', 'jason', 'tank', 'sean'] print(name_list.copy()) # 生成一個新列表,賦值原列表中所有元素 ['nick', 'jason', 'tank', 'sean'] name_list = ['nick', 'jason', 'tank', 'sean'] name_list2 = ['nick handsome'] name_list.extend(name_list2) # 在列表末尾一次性追加另一個序列中的多個值(用新列表擴充套件原來的列表) print(name_list) # ['nick', 'jason', 'tank', 'sean', 'nick handsome'] name_list = ['nick', 'jason', 'tank', 'sean'] name_list.reverse() # 將列表ls中的元素反轉 print(name_list) # ['sean', 'tank', 'jason', 'nick'] name_list = ['nick', 'jason', 'tank', 'sean'] name_list.sort() # 排序,使用用sort列表的元素必須是同型別的 print(name_list) # ['jason', 'nick', 'sean', 'tank'] name_list.sort(reverse=True) # 倒序 print(name_list) # ['tank', 'sean', 'nick', 'jason']
元組是一種列表型別,一旦建立就不能被修改。
color = (0x001100, "blue", creature) # 使用小括號 () 或 tuple() 建立,元素間用逗號分隔。 print(type(color)) # creature = "cat", "dog", "tiger", "human" # 可以使用或不使用小括號。即元組由若干逗號分隔的值組成。 print(type(creature)) #
注意與字串區別:
name_str = ('egon') # ()只是普通包含的意思 name_tuple = ('egon',) # 元組中只包含一個元素時,需要在元素後面新增逗號,否則括號會被當作字串使用: print(type(name_str)) # print(type(name_tuple)) #
索引取值、切片(顧頭不顧尾,步長)、長度len、成員運算in和not in、迴圈、count、index等均同列表,只是不更改值。
元組中的元素值是不允許修改的,但我們可以對元組進行連線組合,如下範例:
tup1 = (12, 34.56); tup2 = ('abc', 'xyz') # 以下修改元組元素操作是非法的。 # tup1[0] = 100 # 建立一個新的元組 tup3 = tup1 + tup2; print(tup3) # (12, 34.56, 'abc', 'xyz')
from collections import namedtuple User = namedtuple('User', 'name sex age') # 定義一個namedtuple型別User,幷包含name,sex和age屬性。 user = User(name='Runoob', sex='male', age=12) # 建立一個User物件 print(user.age) # 12
到此這篇關於Python中的複雜資料型別(list、tuple)的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45