python數(shù)據(jù)類型相關(guān)知識(shí)擴(kuò)展
一、命名元祖
在python基礎(chǔ)中, 我們學(xué)習(xí)元祖的時(shí)候,取元祖內(nèi)部的元素都是通過索引來進(jìn)行取值的。但是這種取值方式不夠友好, 所以我們引入命名元祖的方式對(duì)元祖進(jìn)行字典式取值,這種方式比起字典存儲(chǔ)占用的內(nèi)存較少。如果數(shù)據(jù)不需要變化,可以用命名元祖替代字典。
常規(guī)元祖取值方式:
info = ("flora", 28, "女") name = 0 age = 1 gender = 2 print(info[name]) # 獲取姓名 print(info[age]) # 獲取年齡 print(info[gender]) # 獲取性別
命名元祖方式:
# namedtuple: 接收兩個(gè)參數(shù):第一個(gè)參數(shù)是創(chuàng)建的類型名稱, 第二個(gè)參數(shù)是列表 from collections import namedtuple info = namedtuple("info_key", ["name", "age", "gender"]) info_01 = info("flora", 28, "女") print(info_01.name) # 獲取姓名 print(info_01.age) # 獲取年齡 print(info_01.gender) # 獲取性別 print(info_01) # 打印結(jié)果:info_key(name='flora', age=28, gender='女')
二、在自動(dòng)化測(cè)試場(chǎng)景中的應(yīng)用
我們從excel中讀取用例數(shù)據(jù)第一行表頭是key, 每一行的值是value。如果作為字典格式存儲(chǔ)格式如下:
case = [ {"case_id": 1, "case_title": "正常登錄", "data": "test", "expected": "pass"}, {"case_id": 2, "case_title": "登錄失敗", "data": "test", "expected": "pass"}, ]
我們可以把轉(zhuǎn)成命名元祖的方式存儲(chǔ),如下:
# namedtuple: 接收兩個(gè)參數(shù):第一個(gè)參數(shù)是創(chuàng)建的類型名稱, 第二個(gè)參數(shù)是列表 from collections import namedtuple case = [ {"case_id": 1, "case_title": "正常登錄", "data": "test01", "expected": "pass"}, {"case_id": 2, "case_title": "登錄失敗", "data": "test02", "expected": "pass"}, ] cases = namedtuple("case", case[0].keys()) for i in case: result = cases(*i.values()) print(result.data) # 打印結(jié)果: test01 test02
三、三目運(yùn)算符
python中的三目運(yùn)算符相當(dāng)于java中的三元運(yùn)算符。
- 基本語(yǔ)法
條件成立執(zhí)行的結(jié)果 if 過濾條件 else 條件不成立執(zhí)行的結(jié)果
- 實(shí)際應(yīng)用
例如我們想要編寫一個(gè)Python程序,輸入兩個(gè)數(shù),比較它們的大小并輸出其中較大者。相比起常規(guī)寫法,三目運(yùn)算符寫法更加的簡(jiǎn)潔明了。
常規(guī)寫法:
x = int(input("請(qǐng)輸入第一個(gè)正整數(shù):")) y = int(input("請(qǐng)輸入第二個(gè)正整數(shù):")) if x == y: print("較大的數(shù)為:", x) elif x > y: print("較大的數(shù)為:", x) else: print("較大的數(shù)為:", y)
三目運(yùn)算符寫法:
x = int(input("請(qǐng)輸入第一個(gè)正整數(shù):")) y = int(input("請(qǐng)輸入第二個(gè)正整數(shù):")) print("較大的數(shù)為:{}".format(x if x > y else y))
- 擴(kuò)展: 三目運(yùn)算符的嵌套
Python 三目運(yùn)算符支持嵌套,如此可以構(gòu)成更加復(fù)雜的表達(dá)式。在嵌套時(shí)需要注意 if 和 else 的配對(duì)。
例如我們需要判斷兩個(gè)數(shù)字的關(guān)系。
常規(guī)寫法:
a = int(input("請(qǐng)輸入a:")) b = int(input("請(qǐng)輸入b:")) if a > b: print("a大于b") else: if a < b: print("a小于b") else: print("a等于b")
三目運(yùn)算符嵌套寫法:
a = int(input("請(qǐng)輸入a:")) b = int(input("請(qǐng)輸入b:")) print("a大于b") if a > b else (print("a小于b") if a < b else print("a等于b"))
四、推導(dǎo)式
推導(dǎo)式 comprehensions(又稱解析式),是 python 的一種獨(dú)有特性。推導(dǎo)式是可以從一個(gè)數(shù)據(jù)序列構(gòu)建另一個(gè)新的數(shù)據(jù)序列。 推導(dǎo)式的作用:快速生成數(shù)據(jù)。
列表推導(dǎo)式
- 常規(guī)列表推導(dǎo)式
基本語(yǔ)法:[每次遍歷添加到列表的內(nèi)容 for x in xxx]
實(shí)例:輸出一個(gè)由0-100的數(shù)字組成的列表。
常規(guī)寫法:
li = [] for i in range(101): li.append(i) print(li)
推導(dǎo)式寫法:
li = [i for i in range(101)] print(li)
- 列表推導(dǎo)式嵌套if
基本語(yǔ)法:[每次遍歷添加到列表的內(nèi)容 for x in xxx if 過濾條件]
實(shí)例:輸出一個(gè)由0-100的偶數(shù)數(shù)字組成的列表。
常規(guī)寫法:
li = [] for i in range(101): if i % 2 == 0: li.append(i) print(li)
推導(dǎo)式寫法:
li = [i for i in range(101) if i % 2 == 0] print(li)
- 列表推導(dǎo)式結(jié)合三目運(yùn)算符
基本語(yǔ)法:[if 過濾條件 else 條件 每次遍歷添加到列表的內(nèi)容 for x in xxx ]
實(shí)例:0-100個(gè)數(shù),如果是偶數(shù)則返回偶數(shù)0, 如果是奇數(shù)則返回奇數(shù)1。
常規(guī)寫法:
li = [] for i in range(101): if i % 2 == 0: li.append("偶數(shù)0") else: li.append("奇數(shù)1") print(li)
列表推導(dǎo)式+三目運(yùn)算符:
li = ["偶數(shù)0" if i % 2 == 0 else "奇數(shù)1" for i in range(101)] print(li)
五、字典推導(dǎo)式
基本語(yǔ)法:{鍵:值 獲取鍵值的表達(dá)式}
實(shí)例: 有一個(gè)列表li, 把他轉(zhuǎn)換成一個(gè)元素下標(biāo)為鍵,值為元素的字典格式的數(shù)據(jù)。
常規(guī)寫法:
li = ["id", "title", "url", "data", "expected"] dic = {} for i, j in enumerate(li): dic[i] = j print(dic)
字典推導(dǎo)式寫法:
li = ["id", "title", "url", "data", "expected"] dic = {i: j for i, j in enumerate(li)} print(dic)
到此這篇關(guān)于python數(shù)據(jù)類型相關(guān)知識(shí)擴(kuò)展的文章就介紹到這了,更多相關(guān)python數(shù)據(jù)類型內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python中使用tarfile壓縮、解壓tar歸檔文件示例
這篇文章主要介紹了Python中使用tarfile壓縮、解壓tar歸檔文件示例,本文直接給出解壓和壓縮代碼示例,需要的朋友可以參考下2015-04-04Python實(shí)現(xiàn)Canny及Hough算法代碼實(shí)例解析
這篇文章主要介紹了Python實(shí)現(xiàn)Canny與Hough算法代碼實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08Python基于scipy實(shí)現(xiàn)信號(hào)濾波功能
本文將以實(shí)戰(zhàn)的形式基于scipy模塊使用Python實(shí)現(xiàn)簡(jiǎn)單濾波處理。這篇文章主要介紹了Python基于scipy實(shí)現(xiàn)信號(hào)濾波功能,需要的朋友可以參考下2019-05-05python之語(yǔ)句mode = 'test' if y&nb
這篇文章主要介紹了python之語(yǔ)句mode = 'test' if y is None else 'train'問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02python如何實(shí)現(xiàn)lazy segment tree惰性段樹算法
LazySegmentTree(惰性段樹)算法是一種數(shù)據(jù)結(jié)構(gòu),專門用于高效處理區(qū)間查詢和更新操作,它利用延遲更新技術(shù)(LazyPropagation),僅在必要時(shí)執(zhí)行實(shí)際更新,以提升效率,此結(jié)構(gòu)將數(shù)組表達(dá)為二叉樹,每個(gè)節(jié)點(diǎn)表示一個(gè)數(shù)組區(qū)間2024-10-10