目錄
前言
創建命名元組
命名元組特定方法
结果的实体性赋值
本文小结
首頁 後端開發 Python教學 Python程式設計:詳解命名元組(namedtuple)的使用要點

Python程式設計:詳解命名元組(namedtuple)的使用要點

Apr 11, 2023 pm 09:22 PM
python 程式設計 模組

前言

本文繼續介紹Python集合模組,這次主要簡明扼要的介紹其內的命名元組,即namedtuple的使用。閒話少敘,我們開始-記得按讚、追蹤和轉發哦~ ^_^

創建命名元組

Python集合中的命名元組類namedTuples為元組中的每個位置賦予意義,並增強程式碼的可讀性和描述性。它們可以在任何使用常規元組的地方使用,並且增加了透過名稱而不是位置索引方式存取欄位的能力。其來自Python內建模組collections。其使用的常規語法方式為:

import collections
XxNamedTuple = collections.namedtuple(typename, field_names):
登入後複製

如果導入的方式不同,例如:import collections as cAlias、from collections import namedtuple、from collections import namedtupleTupas namedtuple、from collections import namedtupleTupas namedtuple、from collections import namedtupleTupas namedtuple、from collections import namedtupleTupas Namedtuple、from collections import namedtupleTupas Nameddtuple、fromle等形式可以對應為:

XxNamedTuple = cAlias.namedtuple(……)
XxNamedTuple = namedtuple(……)
XxNamedTuple = NamedTuple(……)
登入後複製

其中:

參數typename:為傳回的新元組子類別XxNamedTuple指定一個字串型類別名稱。新的子類別用於建立類似元組的對象,所建立的對象具有可透過屬性查找、位置索引以及迭代的方式來存取的相關欄位。子類別的實例還有一個有用的文檔字串(相當於幫助文檔,帶有typename和field_names)和一個有用的__repr__()方法,該方法以名稱=值的格式列出元組內容。

參數field_names:是通常是字串序列,如[' x ', ' y ']。作為可選方式,field_names也可以是一個字串,但包含的對應欄位名稱是用空格和/或逗號分隔,例如' x y '或' x, y '。

任何有效的Python標識符都可以用作命名字段名稱,但不能以下劃線(_)開始。有效的識別字包括字母、數字和底線,但不要以數字或底線開始,不能使用關鍵字,如class、return、global、pass或raise等。

為了理解NamedTuple是如何運作的,我們假設有一個Employee對象,其擁有id、name和age屬性。請看程式碼範例清單:

Python程式設計:詳解命名元組(namedtuple)的使用要點

執行程式輸出結果類似如下:

Employee(, name='Solo Cui ', age='18')
按索引方式访问Employee的名子为 : Solo Cui
Employee(, name='Annie Kent', age='26')
按键(字段名)访问Employee的名子为 : Annie Kent
登入後複製

另外,建立命名元組的函數中其它幾個參數用的少,這裡僅作簡單介紹:

參數rename:如果rename為true,無效的欄位名稱將自動替換為位置名稱。例如,['abc', 'def', 'ghi', 'abc']被轉換為['abc', '_1', 'ghi', '_3'],消除了關鍵字def和重複的字段名abc。

參數defaults:可以是None或預設值的可迭代物件。由於具有預設值的欄位必須出現在任何沒有預設值的欄位之後,因此預設值會套用到最右邊的參數,依序向左。例如,如果欄位名稱是['x', 'y', 'z'],預設值是(1,2),那麼x將是一個必需的參數,y將預設值為1,z將預設值為2。

參數module:如果定義了module,則命名元組的__module__屬性設定為該值。

命名元組實例沒有為每個實例單獨使用字典,所以它們是輕量級的,不需要比常規元組更多的記憶體。

命名元組特定方法

除了從元組繼承的方法之外,命名元組還支援另外三個方法和兩個屬性。為了防止與欄位名稱發生衝突,方法和屬性名稱以下劃線開頭。分別介紹如下:

1)_make(iterable):

類別方法,從現有序列或可迭代物件產生新實例。程式碼範例如下:

Python程式設計:詳解命名元組(namedtuple)的使用要點

輸出結果類似如下:

Employee(, name='Batman', age='28')
登入後複製

2)_asdict ():

##返回一個新的字典,它將字段名映射到對應的值。範例程式碼如下:

Python程式設計:詳解命名元組(namedtuple)的使用要點

輸出結果類似如下:

{'id': '333', 'name': 'Batman', 'age': '28'}

登入後複製

3)_replace (**kwargs):

傳回一個命名元組的新實例,用新值取代指定欄位。程式碼範例如下:

Python程式設計:詳解命名元組(namedtuple)的使用要點

輸出結果如下:

Employee(, name='Batman', age='34')
登入後複製

4)_fields:

以字串元群組方式列出欄位名的。用於自省和從現有的命名元組建立新的命名元組類型。範例程式碼如下:

Python程式設計:詳解命名元組(namedtuple)的使用要點

輸出結果為:

('id', 'name', 'age')
登入後複製

我们可以使用_fields属性从现有的命名元组中创建新的命名元组。示例如下:

Python程式設計:詳解命名元組(namedtuple)的使用要點

输出结果类似如下:

Pixel(x=5, y=8, red=128, green=255, blue=0)
登入後複製

结果的实体性赋值

这里所说的实体,类似Java中的数据实体对象——只有简单的属性字段。而命名元组在为csv或sqlite3模块操作而返回的元组结果分配给对应字段名而装配成简单实体时特别有用,自动进行字段的对应赋值。比如在当前Python程序位置有个employees.csv,其包含内容如下:

张三,26,工程师,开发部,中级
李四,32,项目经理,项目部,高级
登入後複製

通过示例,我们来完成Employee实体的命名元组的自动装配,代码示例如下:

Python程式設計:詳解命名元組(namedtuple)的使用要點

输出结果类似如下:

张三 工程师 26 开发部 中级
李四 项目经理 32 项目部 高级
登入後複製

再简单地来个数据库操作和装配实体的示例,代码清单如下:

Python程式設計:詳解命名元組(namedtuple)的使用要點

我这里只是简单的创建了数据库并创建表,然后插入一条数据,再查询并完成命名元组的实体化装配和结果输出。

运行输出结果如下:

王武 经理
登入後複製

本文小结

本文主要介绍了Python自带集合模块中的命名元组(namedtuple)的使用,即可以当做一般的元组使用,由可基于字段名的方式访问元组值,并介绍了命名元组内部扩展的几个方法和和属性的应用示例。最后还介绍了基于命名元组的实体化封装应用。基于代码示例进行介绍,这样便于你动手实践,以便更好地掌握和理解。

以上是Python程式設計:詳解命名元組(namedtuple)的使用要點的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

HadiDB:Python 中的輕量級、可水平擴展的數據庫 HadiDB:Python 中的輕量級、可水平擴展的數據庫 Apr 08, 2025 pm 06:12 PM

HadiDB:輕量級、高水平可擴展的Python數據庫HadiDB(hadidb)是一個用Python編寫的輕量級數據庫,具備高度水平的可擴展性。安裝HadiDB使用pip安裝:pipinstallhadidb用戶管理創建用戶:createuser()方法創建一個新用戶。 authentication()方法驗證用戶身份。 fromhadidb.operationimportuseruser_obj=user("admin","admin")user_obj.

Python:探索其主要應用程序 Python:探索其主要應用程序 Apr 10, 2025 am 09:41 AM

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

2小時的Python計劃:一種現實的方法 2小時的Python計劃:一種現實的方法 Apr 11, 2025 am 12:04 AM

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

Navicat查看MongoDB數據庫密碼的方法 Navicat查看MongoDB數據庫密碼的方法 Apr 08, 2025 pm 09:39 PM

直接通過 Navicat 查看 MongoDB 密碼是不可能的,因為它以哈希值形式存儲。取回丟失密碼的方法:1. 重置密碼;2. 檢查配置文件(可能包含哈希值);3. 檢查代碼(可能硬編碼密碼)。

如何將 AWS Glue 爬網程序與 Amazon Athena 結合使用 如何將 AWS Glue 爬網程序與 Amazon Athena 結合使用 Apr 09, 2025 pm 03:09 PM

作為數據專業人員,您需要處理來自各種來源的大量數據。這可能會給數據管理和分析帶來挑戰。幸運的是,兩項 AWS 服務可以提供幫助:AWS Glue 和 Amazon Athena。

如何針對高負載應用程序優化 MySQL 性能? 如何針對高負載應用程序優化 MySQL 性能? Apr 08, 2025 pm 06:03 PM

MySQL數據庫性能優化指南在資源密集型應用中,MySQL數據庫扮演著至關重要的角色,負責管理海量事務。然而,隨著應用規模的擴大,數據庫性能瓶頸往往成為製約因素。本文將探討一系列行之有效的MySQL性能優化策略,確保您的應用在高負載下依然保持高效響應。我們將結合實際案例,深入講解索引、查詢優化、數據庫設計以及緩存等關鍵技術。 1.數據庫架構設計優化合理的數據庫架構是MySQL性能優化的基石。以下是一些核心原則:選擇合適的數據類型選擇最小的、符合需求的數據類型,既能節省存儲空間,又能提升數據處理速度

redis怎麼啟動服務器 redis怎麼啟動服務器 Apr 10, 2025 pm 08:12 PM

啟動 Redis 服務器的步驟包括:根據操作系統安裝 Redis。通過 redis-server(Linux/macOS)或 redis-server.exe(Windows)啟動 Redis 服務。使用 redis-cli ping(Linux/macOS)或 redis-cli.exe ping(Windows)命令檢查服務狀態。使用 Redis 客戶端,如 redis-cli、Python 或 Node.js,訪問服務器。

redis怎麼讀取隊列 redis怎麼讀取隊列 Apr 10, 2025 pm 10:12 PM

要從 Redis 讀取隊列,需要獲取隊列名稱、使用 LPOP 命令讀取元素,並處理空隊列。具體步驟如下:獲取隊列名稱:以 "queue:" 前綴命名,如 "queue:my-queue"。使用 LPOP 命令:從隊列頭部彈出元素並返回其值,如 LPOP queue:my-queue。處理空隊列:如果隊列為空,LPOP 返回 nil,可先檢查隊列是否存在再讀取元素。

See all articles