說到python的數(shù)據(jù)類型,很多小伙伴都能舉出很多例子:字符串,字典,int,float,列表,元組等。但還有一些比較小眾的數(shù)據(jù)類型,比如接下來我們要介紹的python命名元組。另外還有一些初學(xué)者比較少接觸到的操作,比如三目運(yùn)算符和python推導(dǎo)式。那么接下來就和小編來一起學(xué)習(xí)這些內(nèi)容吧!
一、命名元組
在python基礎(chǔ)中, 我們學(xué)習(xí)元組的時(shí)候,取元組內(nèi)部的元素都是通過索引來進(jìn)行取值的。但是這種取值方式不夠友好, 所以我們引入命名元組的方式對元組進(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)化測試場景中的應(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)算符。
- 基本語法
條件成立執(zhí)行的結(jié)果 if 過濾條件 else 條件不成立執(zhí)行的結(jié)果
- 實(shí)際應(yīng)用
例如我們想要編寫一個(gè)Python程序,輸入兩個(gè)數(shù),比較它們的大小并輸出其中較大者。相比起常規(guī)寫法,三目運(yùn)算符寫法更加的簡潔明了。
常規(guī)寫法:
x = int(input("請輸入第一個(gè)正整數(shù):"))
y = int(input("請輸入第二個(gè)正整數(shù):"))
if x == y:
print("較大的數(shù)為:", x)
elif x > y:
print("較大的數(shù)為:", x)
else:
print("較大的數(shù)為:", y)
三目運(yùn)算符寫法:
x = int(input("請輸入第一個(gè)正整數(shù):"))
y = int(input("請輸入第二個(gè)正整數(shù):"))
print("較大的數(shù)為:{}".format(x if x > y else y))
- 擴(kuò)展: 三目運(yùn)算符的嵌套
Python 三目運(yùn)算符支持嵌套,如此可以構(gòu)成更加復(fù)雜的表達(dá)式。在嵌套時(shí)需要注意 if 和 else 的配對。
例如我們需要判斷兩個(gè)數(shù)字的關(guān)系。
常規(guī)寫法:
a = int(input("請輸入a:"))
b = int(input("請輸入b:"))
if a > b:
print("a大于b")
else:
if a < b:
print("a小于b")
else:
print("a等于b")
三目運(yùn)算符嵌套寫法:
a = int(input("請輸入a:"))
b = int(input("請輸入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)式
基本語法:[每次遍歷添加到列表的內(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
基本語法:[每次遍歷添加到列表的內(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)算符
基本語法:[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)式
基本語法:{鍵:值 獲取鍵值的表達(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)
小結(jié)
不管是python命名元組,還是python三目運(yùn)算符,亦或者是python推導(dǎo)式,這些都屬于python數(shù)據(jù)類型的拓展,到此這篇關(guān)于python數(shù)據(jù)類型擴(kuò)展的文章就介紹到這了,更多python數(shù)據(jù)類型拓展內(nèi)容可以搜索W3Cschool以前的文章進(jìn)行學(xué)習(xí)!