国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

【Python 高級(jí)特性】深入 NamedTuple 命名元組

這篇具有很好參考價(jià)值的文章主要介紹了【Python 高級(jí)特性】深入 NamedTuple 命名元組。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。

介紹

和元組 tuple 一樣,NamedTuple 也是不可變數(shù)據(jù)類型,創(chuàng)建之后就不能改變內(nèi)容。
如其名,和 tuple 的區(qū)別在于“Named”,即"命名"。NamedTuple 不像數(shù)組那樣使用下標(biāo)讀寫(xiě),反而和類相似,使用 . 來(lái)讀寫(xiě)。

基本語(yǔ)法

創(chuàng)建 NamedTuple 的函數(shù)定義

collections.namedtuple(typename, field_names, *, rename=False, defaults=None, module=None)

參數(shù)說(shuō)明:

  • typename:新創(chuàng)建的類的名稱。
  • field_names:字段名稱列表。必須是有效的 Python 變量名稱,且不能以下劃線開(kāi)頭。
  • rename:是否自動(dòng)轉(zhuǎn)換無(wú)效字段名。
  • defaults:字段默認(rèn)值列表。
  • module__module__ 的值。

使用教程

創(chuàng)建

首先看看如何創(chuàng)建命名元組。以 Point(代表二維坐標(biāo)中的一個(gè)點(diǎn))為例:

# 導(dǎo)包
from collections import namedtuple

# 創(chuàng)建普通元組
point = (22, 33)
print(point) # 輸出:(22, 33)

# 創(chuàng)建命名元組
Point = namedtuple('Point', 'x y')
point_A = Point(22, 33)
print(point_A) # 輸出:Point(x=22, y=33)

重點(diǎn)是這兩句話

Point = namedtuple('Point', 'x y')
point_A = Point(22, 33)

需要注意,namedtuple() 是用來(lái)創(chuàng)建類的,不是創(chuàng)建對(duì)象實(shí)例!

我們先用 namedtuple 創(chuàng)建了一個(gè)名為 Point,有兩個(gè)字段 x、y 的子類,然后將這個(gè)類賦給 Point 變量。
然后 Point(22, 33) 就是普通的 new 的語(yǔ)法。

類似于如下代碼:

class Point:
	def __init__(self, x, y):
		self.x = x
		self.y = y
point_A = Point(22, 33)

創(chuàng)建命名元組對(duì)象時(shí),也可以使用位置參數(shù)

a = Point(1, 2)
b = Point(y=2, x=1)
a == b # >>> True

field_names 參數(shù)用來(lái)設(shè)置命名元組字段名,有三種風(fēng)格可以選擇。
下面幾種都是等價(jià)寫(xiě)法:

Point = namedtuple('Point', 'x y')
Point = namedtuple('Point', 'x,y')
Point = namedtuple('Point', ['x', 'y'])


# 下面都是合法代碼
# 中間允許存在任意空白字符
Point = namedtuple('Point', 'x,   \t\t\t\n\n y')
Point = namedtuple('Point', 'x   \t\t\t\n\n y')
# 元組也可以
Point = namedtuple('Point', ('x', 'y'))
# 事實(shí)上只要是可迭代都行
def fields():
	yield 'x'
	yield 'y'
Point = namedtuple('Point', fields())

使用

命名元組首先是一個(gè)元組,元組能怎么用,命名元組當(dāng)然也可以。

print(point_A[0])
print(point_A[1])
print(*point_A) # tuple unpack

# 輸出
"""
22
33
22 33
"""

然后是命名元組的特殊用法:

print(point_A.x)
print(point_A.y)

# 輸出
"""
22
33
"""

常用方法

namedtuple 創(chuàng)建的類還附贈(zèng)了一些實(shí)用方法:

Point._make(iterable) # 從某個(gè)序列創(chuàng)建命名元組
point._asdict() # 轉(zhuǎn)成字典
point._replace(**kargs) # 返回一個(gè)新元組,新元組里的指定字段被替換為指定值

point._fields # 列出字段名
point._field_defaults # 列出字段默認(rèn)值

設(shè)置默認(rèn)值

可以為命名元組的字段設(shè)置默認(rèn)值,只需要在創(chuàng)建類的時(shí)候傳入 defaults 參數(shù)即可。

# 四維向量
# 默認(rèn)值為 Vector4D(0, 0, 0, 0)
Vector4 = namedtuple('Vector4D', 'x y z w', defaults=(0, 0, 0, 0))

v1 = Vector4()
v2 = Vector4(1)
v3 = Vector4(1, 2, w=4)
print(v1)
print(v2)
print(v3)

# 輸出
"""
Vector4D(x=0, y=0, z=0, w=0)
Vector4D(x=1, y=0, z=0, w=0)
Vector4D(x=1, y=2, z=0, w=4)
"""

默認(rèn)值的數(shù)量可以小于字段數(shù),表示為右邊 n 個(gè)參數(shù)設(shè)置默認(rèn)值。

Foo = namedtuple('Foo', 'a b c d', defaults=(1, 2))
print(Foo(22, 33))
print(Foo())

# 輸出
"""
Foo(a=22, b=33, c=1, d=2)
Traceback (most recent call last):
  File "D:\TempCodeFiles\named_tuple.py", line 6, in <module>
    print(Foo())
TypeError: Foo.__new__() missing 2 required positional arguments: 'a' and 'b'
"""

更好的表示方式

namedtuple() 的寫(xiě)法既不直觀,也不優(yōu)雅。Python 3.5 新增了一種更好的寫(xiě)法:

# >= Python 3.5
from typing import NamedTuple
class PointA(NamedTuple):
	x: int = 0
	y: int = 0

# >= Python 2
from collections import namedtuple
PointB = namedtuple('PointB', 'x y', defaults=(0, 0))

print(PointA(2, 3) == PointB(2, 3)) # 輸出:True

繼承并擴(kuò)展 NamedTuple

namedtuple() 返回的是一個(gè)正常的類。既然它是一個(gè)類,當(dāng)然也可以被繼承。

創(chuàng)建一個(gè) Point 命名元組,增加一個(gè)方法,求兩點(diǎn)距離。

# >= Python 3.5
class Point(NamedTuple):
	x: int = 0
	y: int = 0
    
	def distance(self, p) -> float:
		return math.sqrt((self.x - p.x) ** 2 + (self.y - p.y) ** 2)

# >= Python 2
class Point(namedtuple('Point', 'x y', defaults=(0, 0))):
	def distance(self, p) -> float:
		return math.sqrt((self.x - p.x) ** 2 + (self.y - p.y) ** 2)

a = Point()
b = Point(3, 2)
print(a, b)
print(a.distance(b))

應(yīng)用

讀 csv 文件

以讀入一個(gè)儲(chǔ)存英語(yǔ)單詞的 csv 文件為例。

import csv
from collections import namedtuple

# 定義命名元組
# 按照 csv 列名來(lái)定義字段
Word = namedtuple('Word', 'word, type, chs_def, eng_ch, context, example')

file_path = r'C:\Users\ZhouXiaokang\Desktop\單詞 Vol 1 Ch 1 Ep 2.csv'
with open(file_path, 'r', encoding='utf-8') as f:
	reader = csv.reader(f)
	next(reader) # 跳過(guò)標(biāo)題行
	for word in map(Word._make, reader):
		print(f'{word.word} {word.type}. {word.chs_def} | 例:{word.context}')

輸出

chirp n&v. (鳥(niǎo)、昆蟲(chóng))啾啾叫,發(fā)唧唧聲 | 例:(*chirp* *chirp* *chirp*)
screech v. (車輛、汽車輪胎)發(fā)出刺耳聲 | 例:(*screech*)
Shiroko term. 白子 | 例:
mug v. 對(duì)…行兇搶劫 | 例:You didn't get mugged, did you?
faint v. 暈厥;暈倒 | 例:What's that? You fainted from hunger?
......

作為字典的代替品表示數(shù)據(jù)

相對(duì)于字典的優(yōu)勢(shì):
1.快、小
2..field['field'] 更清晰

以下源碼摘自 baidupcs_py 庫(kù):

class PcsFile(NamedTuple):
    """
    A Baidu PCS file

    path: str  # remote absolute path
    is_dir: Optional[bool] = None
    is_file: Optional[bool] = None
    fs_id: Optional[int] = None  # file id
    size: Optional[int] = None
    md5: Optional[str] = None
    block_list: Optional[List[str]] = None  # block md5 list
    category: Optional[int] = None
    user_id: Optional[int] = None
    ctime: Optional[int] = None  # server created time
    mtime: Optional[int] = None  # server modifed time
    local_ctime: Optional[int] = None  # local created time
    local_mtime: Optional[int] = None  # local modifed time
    server_ctime: Optional[int] = None  # server created time
    server_mtime: Optional[int] = None  # server modifed time
    shared: Optional[bool] = None  # this file is shared if True
    """

    path: str  # remote absolute path
    is_dir: Optional[bool] = None
    is_file: Optional[bool] = None
    fs_id: Optional[int] = None  # file id
    size: Optional[int] = None
    md5: Optional[str] = None
    block_list: Optional[List[str]] = None  # block md5 list
    category: Optional[int] = None
    user_id: Optional[int] = None
    ctime: Optional[int] = None  # server created time
    mtime: Optional[int] = None  # server modifed time
    local_ctime: Optional[int] = None  # local created time
    local_mtime: Optional[int] = None  # local modifed time
    server_ctime: Optional[int] = None  # server created time
    server_mtime: Optional[int] = None  # server modifed time
    shared: Optional[bool] = None  # this file is shared if True

    rapid_upload_info: Optional[PcsRapidUploadInfo] = None
    dl_link: Optional[str] = None

    @staticmethod
    def from_(info) -> "PcsFile":
        return PcsFile(
            path=info.get("path"),
            is_dir=info.get("isdir") == 1,
            is_file=info.get("isdir") == 0,
            fs_id=info.get("fs_id"),
            size=info.get("size"),
            md5=info.get("md5"),
            block_list=info.get("block_list"),
            category=info.get("category"),
            user_id=info.get("user_id"),
            ctime=info.get("ctime"),
            mtime=info.get("mtime"),
            local_ctime=info.get("local_ctime"),
            local_mtime=info.get("local_mtime"),
            server_ctime=info.get("server_ctime"),
            server_mtime=info.get("server_mtime"),
            shared=info.get("shared"),
        )

源碼

見(jiàn) Github。

關(guān)鍵部分在這里:

    # Build-up the class namespace dictionary
    # and use type() to build the result class
    # 收集類的方法、字段等
    class_namespace = {
        '__doc__': f'{typename}({arg_list})',
        '__slots__': (),
        '_fields': field_names,
        '_field_defaults': field_defaults,
        '__new__': __new__,
        '_make': _make,
        '__replace__': _replace,
        '_replace': _replace,
        '__repr__': __repr__,
        '_asdict': _asdict,
        '__getnewargs__': __getnewargs__,
        '__match_args__': field_names,
    }
    for index, name in enumerate(field_names):
        doc = _sys.intern(f'Alias for field number {index}')
        class_namespace[name] = _tuplegetter(index, doc)

    # 創(chuàng)建新類
    result = type(typename, (tuple,), class_namespace) 

type() 函數(shù)傳入一個(gè)參數(shù),用來(lái)獲取對(duì)象的類;如果傳入三個(gè)參數(shù),就變成了動(dòng)態(tài)創(chuàng)建類,相當(dāng)于 class 的動(dòng)態(tài)寫(xiě)法。文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-848081.html

class Foo:
    def hello(self):
        print('Hello')
# 等價(jià)于
def hello(self):
    print('Hello')
Foo = type('Foo', (object,), {'hello': hello})

參考文章

  1. https://docs.python.org/zh-cn/3/library/collections.html#collections.namedtuple
  2. https://realpython.com/python-namedtuple/

到了這里,關(guān)于【Python 高級(jí)特性】深入 NamedTuple 命名元組的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 重溫《深入理解Java虛擬機(jī):JVM高級(jí)特性與最佳實(shí)踐(第二版)》 –– 學(xué)習(xí)筆記(一)

    第1章:走近Java 1.1 Java的技術(shù)體系 SUN 官方所定義的 Java 技術(shù)體系包括:Java程序設(shè)計(jì)語(yǔ)言、Java虛擬機(jī)、Class文件格式、Java API類庫(kù)、第三方(商業(yè)機(jī)構(gòu)和開(kāi)源社區(qū))Java類庫(kù)。 其中,「Java程序設(shè)計(jì)語(yǔ)言」、「Java虛擬機(jī)」、「Java API類」這三個(gè)被稱為 JDK(Java Deployment Kit),即

    2024年01月23日
    瀏覽(21)
  • 《深入理解Java虛擬機(jī):JVM高級(jí)特性與最佳實(shí)踐(第3版) 周志明》 - 第12章代碼示例

    ? ? ? ? 最近在看《深入理解Java虛擬機(jī):JVM高級(jí)特性與最佳實(shí)踐(第3版) 周志明》這本書(shū),書(shū)中有些代碼示例是為了讓讀者理解作者表達(dá)的意思,但不是完整的代碼示例,所以針對(duì)這些不完整的代碼,自己動(dòng)手寫(xiě)出完整的代碼示例。 (1)在看這本書(shū)的同學(xué),可以拿我這里的示

    2024年01月22日
    瀏覽(22)
  • python-高級(jí)特性

    python-高級(jí)特性

    列表生成式就是一個(gè)用來(lái)生成列表的特定語(yǔ)法形式的表達(dá)式。是Python提供的一種生成列表的簡(jiǎn)潔形式, 可快速生成一個(gè)新的list。 普通 的語(yǔ)法格式:[exp for iter_var in iterable] 帶過(guò)濾功能 語(yǔ)法格式: [exp for iter_var in iterable if_exp] 循環(huán)嵌套 語(yǔ)法格式: [exp for iter_var_A in iterable_A for it

    2024年02月08日
    瀏覽(20)
  • C++11 新特性:tuple 元組

    std::tuple 是 C++11 中引入的一個(gè)非常強(qiáng)大的類型,它允許將多個(gè)類型不同的值,組合成單一對(duì)象。 std::tuple 非常適合用于那些需要返回多個(gè)值的場(chǎng)景,而且它的靈活性和通用性使得其成為現(xiàn)代 C++ 編程中不可或缺的一部分。下面,我們將探討一下 std::tuple 的內(nèi)部實(shí)現(xiàn)、使用場(chǎng)景

    2024年04月14日
    瀏覽(26)
  • (三十三)補(bǔ)充Python經(jīng)典面試題(吸收高級(jí)編程特性)

    這個(gè)函數(shù)定義有一個(gè)默認(rèn)參數(shù)b,它的默認(rèn)值是一個(gè)空列表[]。這道面試題涉及到Python中 函數(shù)參數(shù)默認(rèn)值的一些重要概念和陷阱 。 首先,當(dāng)你調(diào)用這個(gè)函數(shù)時(shí),如果不傳遞參數(shù)b的值,它將使用默認(rèn)的空列表[]。例如: 但是,這里有一個(gè)陷阱。默認(rèn)參數(shù)b(即空列表[])在函數(shù)定

    2024年02月04日
    瀏覽(24)
  • 深入NLTK:Python自然語(yǔ)言處理庫(kù)高級(jí)教程

    在前面的初級(jí)和中級(jí)教程中,我們了解了NLTK庫(kù)中的基本和進(jìn)階功能,如詞干提取、詞形還原、n-gram模型和詞云的繪制等。在本篇高級(jí)教程中,我們將深入探索NLTK的更多高級(jí)功能,包括句法解析、命名實(shí)體識(shí)別、情感分析以及文本分類。 句法解析是自然語(yǔ)言處理中的一項(xiàng)重要

    2024年02月14日
    瀏覽(97)
  • 深入Matplotlib:畫(huà)布分區(qū)與高級(jí)圖形展示【第33篇—python:Matplotlib】

    深入Matplotlib:畫(huà)布分區(qū)與高級(jí)圖形展示【第33篇—python:Matplotlib】

    Matplotlib是一個(gè)強(qiáng)大的Python繪圖庫(kù),通過(guò)其靈活的畫(huà)布分區(qū)技術(shù),用戶可以在一個(gè)畫(huà)布上創(chuàng)建多個(gè)子圖,以更清晰地呈現(xiàn)數(shù)據(jù)圖形。本文將深入介紹Matplotlib中的畫(huà)布分區(qū)方法,并通過(guò)實(shí)例演示如何在子圖中展示不同類型的數(shù)據(jù)。 首先,我們使用 plt.subplot() 方法來(lái)實(shí)現(xiàn)畫(huà)布分區(qū)

    2024年01月23日
    瀏覽(26)
  • 開(kāi)啟C++之旅(上):探索命名空間與函數(shù)特性(缺省參數(shù)和函數(shù)重載)

    開(kāi)啟C++之旅(上):探索命名空間與函數(shù)特性(缺省參數(shù)和函數(shù)重載)

    之前淺顯的講解了數(shù)據(jù)結(jié)構(gòu)的部分內(nèi)容:數(shù)據(jù)結(jié)構(gòu)專欄 那么今天我們迎來(lái)了新的起點(diǎn):C++的探索之旅 在c中: 嚴(yán)格的編譯器會(huì)直接 報(bào)錯(cuò) : rand我們都知道是產(chǎn)生隨機(jī)數(shù)的函數(shù),現(xiàn)在我定義了一個(gè)全局變量rand,顯然是有 命名沖突 所以c++就提供了解決方案 想必學(xué)過(guò)c的大家第一

    2024年02月01日
    瀏覽(29)
  • 高級(jí)篇-rabbitmq的高級(jí)特性

    高級(jí)篇-rabbitmq的高級(jí)特性

    ? ? ?啟動(dòng)MQ 創(chuàng)建Queues:? 兩種Callback: 1.ReturnCallback:全局callback? ?2.ComfirmCallback:?發(fā)送信息時(shí)候設(shè)置 ? ?執(zhí)行成功: ?監(jiān)控頁(yè)面: 模擬失?。??1.投遞到交互機(jī)失敗 2.投遞到交換機(jī)了,但是沒(méi)有進(jìn)入隊(duì)列? ? ?注意: ? 演示數(shù)據(jù)是否默認(rèn)持久化:? ? ? ?重啟mq: ?1. 交互機(jī)、

    2024年02月09日
    瀏覽(25)
  • 【實(shí)體識(shí)別】深入淺出講解命名實(shí)體識(shí)別(介紹、常用算法)

    【實(shí)體識(shí)別】深入淺出講解命名實(shí)體識(shí)別(介紹、常用算法)

    本文收錄于《深入淺出講解自然語(yǔ)言處理》專欄,此專欄聚焦于自然語(yǔ)言處理領(lǐng)域的各大經(jīng)典算法,將持續(xù)更新,歡迎大家訂閱! 個(gè)人主頁(yè):有夢(mèng)想的程序星空 個(gè)人介紹:小編是人工智能領(lǐng)域碩士,全棧工程師,深耕Flask后端開(kāi)發(fā)、數(shù)據(jù)挖掘、NLP、Android開(kāi)發(fā)、自動(dòng)化等領(lǐng)域

    2023年04月08日
    瀏覽(46)

覺(jué)得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包