23 - 集合與映射類型

来源:https://www.cnblogs.com/wanderoff-night/p/18020652
-Advertisement-
Play Games

集合與映射類型 集合類型(Set Type) 集合類型對象是由具有唯一性的可哈希對象所組成的無序多項集。 由於集合類型是無序的,它並不記錄元素位置或插入順序,因此集合類型不支持索引、切片或其他序列類的操作。 類型 對應關鍵字 構造函數 是否可變 是否可哈希 set set set() 可變 不可哈希 ...


集合與映射類型

集合類型(Set Type)

集合類型對象是由具有唯一性的可哈希對象所組成的無序多項集。

由於集合類型是無序的,它並不記錄元素位置或插入順序,因此集合類型不支持索引、切片或其他序列類的操作。

類型 對應關鍵字 構造函數 是否可變 是否可哈希
set set set() 可變 不可哈希
frozenset frozenset frozenset() 不可變 可哈希

setfrozenset 的構建方式:

  • 使用花括弧內以逗號分隔元素的方式: {'jack', 'sjoerd'}
  • 使用集合推導式: {c for c in 'abracadabra' if c not in 'abc'}
  • 使用類型構造器: set(), set('foobar'), set(['a', 'b', 'foo'])

frozenset 可通過構造函數 frozenset() 來創建:

class set([iterable])
class frozenset([iterable])

上述倆種構建器輸入一個可迭代對象( iterable )返回一個新的 setfrozenset 對象。 如果未指定可迭代對象,則將返回一個新的空集合。

由於集合的元素必須為可哈希的,因此元素為集合的集合,其所有的內層集合必須為 frozenset對象。

集合類型通用操作 (可用於 setfrozenset)

下表中 s 代表多項集(collection),x 是任何滿足 s 所規定的類型和值限制的任意對象,set代表集合,other代表另一集合。

( union()intersection()difference()symmetric_difference()issubset()issuperset() 方法可以接受任何可迭代對象作為參數, 而基於運算符的對應方法則要求參數為集合對象。)
(混合了 set 實例與 frozenset 的二進位位運算將返回與第一個操作數相同的類型。例如: frozenset('ab') | set('bc') 將返回 frozenset 的實例。)

操作 操作說明
len(s) 返回集合 s 中的元素數量(即 s 的基數)。
x in s 檢測 x 是否為 s 中的成員。
x not in s 檢測 x 是否非 s 中的成員。
isdisjoint(other) 如果集合中沒有與 other 共有的元素則返回 True。 當且僅當兩個集合的交集為空集合時,兩者為不相交集合。
set <= otherissubset(other) 檢測是否集合中的每個元素都在 other 之中。
set < other 檢測集合是否為 other 的真子集,即 set <= other and set != other
set >= otherissuperset(other) 檢測是否 other 中的每個元素都在集合之中。
set > other 檢測集合是否為 other 的真超集,即 set >= other and set != other
set | other | ...union(others) 返回一個新集合,其中包含來自原集合以及 others 指定的所有集合中的元素。
set & other & ...intersection(others) 返回一個新集合,其中包含原集合以及 others 指定的所有集合中共有的元素。
set - other - ...difference(others) 返回一個新集合,其中包含原集合中在 others 指定的其他集合中不存在的元素。
set ^ othersymmetric_difference(others) 返回一個新集合,其中的元素或屬於原集合或屬於 other 指定的其他集合,但不能同時屬於兩者。
copy() 返回原集合的淺拷貝。

可用於 set 但不可用於 frozenset 的操作

下表中 set代表集合,other代表另一集合。elem代表滿足set所有要求的元素。

操作 操作說明
set |= other | ...update(others) 更新集合,添加來自 others 中的所有元素。
set &= other & ...intersection_update(others) 更新集合,只保留其中在所有 others 中也存在的元素。
set -= other | ...difference_update(others) 更新集合,移除其中也存在於 others 中的元素。
set ^= othersymmetric_difference_update(others) 更新集合,只保留存在於集合的一方而非共同存在的元素。
add(elem) 將元素 elem 添加到集合中。
remove(elem) 從集合中移除元素 elem。 如果 elem 不存在於集合中則會引發KeyError
discard(elem) 如果元素 elem 存在於集合中則將其移除。
pop() 從集合中移除並返回任意一個元素。 如果集合為空則會引發KeyError
clear() 從集合中移除所有元素。

映射類型 - 字典(dict)

映射(mapping)類型對象會將可哈希值映射到任意對象。 映射屬於可變對象。字典是內置的映射類型。

字典由鍵值對構成。字典的鍵(key)可以是任何可哈希值,而值可以是任意對象。

字典的構造方式:

  • 使用花括弧內以逗號分隔 鍵: 值 對的方式: {'jack': 4098, 'sjoerd': 4127} or {4098: 'jack', 4127: 'sjoerd'}
  • 使用字典推導式: {}, {x: x ** 2 for x in range(10)}
  • 使用類型構造器: dict(), dict([('foo', 100), ('bar', 200)]), dict(foo=100, bar=200)

構造過程中:

  • 如果沒有給出位置參數,將創建一個空字典。
  • 如果給出一個位置參數並且其屬於映射對象,將創建一個具有與映射對象相同鍵值對的字典。
  • 否則的話,位置參數必須為一個 iterable對象。 該可迭代對象中的每一項本身必須為一個剛好包含兩個元素的可迭代對象。 每一項中的第一個對象將成為新字典的一個鍵,第二個對象將成為其對應的值。
  • 如果一個鍵出現一次以上,該鍵的最後一個值將成為其在新字典中對應的值。
  • 如果給出了關鍵字參數,則關鍵字參數及其值會被加入到基於位置參數創建的字典。
  • 如果要加入的鍵已存在,來自關鍵字參數的值將替代來自位置參數的值。

可用於字典(dict)的操作

d 代表一個字典

操作 操作說明
list(d) 返回字典 d 中使用的所有鍵的列表。
len(d) 返回字典 d 中的項數。
d[key] 返回 d 中以 key 為鍵的項。 如果映射中不存在 key 則會引發 KeyError
d[key] = value d[key] 設為 value
del d[key] d[key]d 中移除。 如果映射中不存在 key 則會引發 KeyError
key in d 如果 d 中存在鍵 key 則返回 True,否則返回 False
key not in d 等價於 not key in d
iter(d) 返回以字典的鍵為元素的迭代器。 這是 iter(d.keys()) 的快捷方式。
clear() 移除字典中的所有元素。
copy() 返回原字典的淺拷貝。
d | other 合併 dother 中的鍵和值來創建一個新的字典,兩者必須都是字典。當 dother 有相同鍵時, other 的值優先。
d |= other other 的鍵和值更新字典 dother 可以是 mappingiterable 的鍵值對。當 dother 有相同鍵時, other 的值優先。

ref:
Python 文檔:集合類型 set 與 frozenset
Python 文檔:映射類型 dict


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 訂單履約系統用來管理從接到銷售訂單,到把貨品送到客戶手中的整個業務過程。它是上游交易(如銷售和客戶下單環節)和下游倉儲配送(如庫存管理、物流)之間的橋梁,確保信息流的順暢和操作的協同,提升整個供應鏈的效率和響應速度。 ...
  • 概括 這是一道PHP反序列化的CTF賽題,本意是想用這道題對PHP反序列化進行一定的學習。 過程 我們打開賽題,看看內容 沒有發現什麼東西,看看他的頁面代碼 根據他的提示,感覺是存在一個robots.txt文件的,嘗試訪問一下。 進去看看。 果然如此 我們來分析一下這段代碼 <?php error_ ...
  • 我們在《SqlSugar開發框架》中,有時候都會根據一些需要引入一些設計模式,主要的目的是為瞭解決問題提供便利和代碼重用等目的。而不是為用而用,我們的目的是解決問題,併在一定的場景下以水到渠成的方式處理。不過引入任何的設計模式,都會增加一定的學習難度,除非是自己本身領會比較好了,就會顯得輕鬆一些。本... ...
  • 一、OpenAL的原理和基本概念: 1.1 OpenAL的架構 OpenAL的架構同樣基於三個核心組件:Context(上下文)、Source(聲源)和Buffer(緩衝區)。Context代表了音頻處理的環境,Source是具體的音頻播放源,而Buffer則用於存儲音頻數據。 1.2 音頻渲染流程 ...
  • Admin3 —— 一個輕巧的後臺管理框架,項目後端基於 Java17、SpringBoot3.0,前端基於 TypeScript、Vite3、Vue3、Element Plus,提供登錄會話、用戶管理、角色管理、許可權資源管理、事件日誌、對象存儲等基礎功能。 ...
  • MQTT 概述 MQTT是基於TCP/IP協議棧構建的非同步通信消息協議,是一種輕量級的發佈、訂閱信息傳輸協議。 可以在不可靠的網路環境中進行擴展,適用於設備硬體存儲空間或網路帶寬有限的場景。 使用MQTT協議,消息發送者與接收者不受時間和空間的限制。 Docker 部署 MQTT(採用docker- ...
  • C-15.存儲過程和函數 MySQL從5.0版本開始支持存儲過程和函數。存儲過程和函數能夠將複雜的SQL邏輯封裝在一起,應用程式無須關註存儲過程和函數內部複雜的SQL邏輯,而只需要簡單地調用存儲過程和函數即可。 1.存儲過程概述 1.1 理解 含義:存儲過程的英文是Stored Procedure。 ...
  • Java 類屬性 Java 類屬性,也稱為欄位,是類中的變數。它們用於存儲與類相關的數據。 創建類屬性 在類定義中聲明屬性: public class Main { int x; // 屬性 String name; // 屬性 } 訪問類屬性 使用點語法訪問對象的屬性: Main myObj = ...
一周排行
    -Advertisement-
    Play Games
  • PasteSpider是什麼? 一款使用.net編寫的開源的Linux容器部署助手,支持一鍵發佈,平滑升級,自動伸縮, Key-Value配置,項目網關,環境隔離,運行報表,差量升級,私有倉庫,集群部署,版本管理等! 30分鐘上手,讓開發也可以很容易的學會在linux上部署你得項目! [從需求角度介 ...
  • SQLSugar是什麼 **1. 輕量級ORM框架,專為.NET CORE開發人員設計,它提供了簡單、高效的方式來處理資料庫操作,使開發人員能夠更輕鬆地與資料庫進行交互 2. 簡化資料庫操作和數據訪問,允許開發人員在C#代碼中直接操作資料庫,而不需要編寫複雜的SQL語句 3. 支持多種資料庫,包括但 ...
  • 在C#中,經常會有一些耗時較長的CPU密集型運算,因為如果直接在UI線程執行這樣的運算就會出現UI不響應的問題。解決這類問題的主要途徑是使用多線程,啟動一個後臺線程,把運算操作放在這個後臺線程中完成。但是原生介面的線程操作有一些難度,如果要更進一步的去完成線程間的通訊就會難上加難。 因此,.NET類 ...
  • 一:背景 1. 講故事 前些天有位朋友在微信上丟了一個崩潰的dump給我,讓我幫忙看下為什麼出現了崩潰,在 Windows 的事件查看器上顯示的是經典的 訪問違例 ,即 c0000005 錯誤碼,不管怎麼說有dump就可以上windbg開幹了。 二:WinDbg 分析 1. 程式為誰崩潰了 在 Wi ...
  • CSharpe中的IO+NPOI+序列化 文件文件夾操作 學習一下常見的文件、文件夾的操作。 什麼是IO流? I:就是input O:就是output,故稱:輸入輸出流 將數據讀入記憶體或者記憶體輸出的過程。 常見的IO流操作,一般說的是[記憶體]與[磁碟]之間的輸入輸出。 作用 持久化數據,保證數據不再 ...
  • C#.NET與JAVA互通之MD5哈希V2024 配套視頻: 要點: 1.計算MD5時,SDK自帶的計算哈希(ComputeHash)方法,輸入輸出參數都是byte數組。就涉及到字元串轉byte數組轉換時,編碼選擇的問題。 2.輸入參數,字元串轉byte數組時,編碼雙方要統一,一般為:UTF-8。 ...
  • CodeWF.EventBus,一款靈活的事件匯流排庫,實現模塊間解耦通信。支持多種.NET項目類型,如WPF、WinForms、ASP.NET Core等。採用簡潔設計,輕鬆實現事件的發佈與訂閱。通過有序的消息處理,確保事件得到妥善處理。簡化您的代碼,提升系統可維護性。 ...
  • 一、基本的.NET框架概念 .NET框架是一個由微軟開發的軟體開發平臺,它提供了一個運行時環境(CLR - Common Language Runtime)和一套豐富的類庫(FCL - Framework Class Library)。CLR負責管理代碼的執行,而FCL則提供了大量預先編寫好的代碼, ...
  • 本章將和大家分享在ASP.NET Core中如何使用高級客戶端NEST來操作我們的Elasticsearch。 NEST是一個高級別的Elasticsearch .NET客戶端,它仍然非常接近原始Elasticsearch API的映射。所有的請求和響應都是通過類型來暴露的,這使得它非常適合快速上手 ...
  • 參考delphi的代碼更改為C# Delphi 檢測密碼強度 規則(仿 google) 仿 google 評分規則 一、密碼長度: 5 分: 小於等於 4 個字元 10 分: 5 到 7 字元 25 分: 大於等於 8 個字元 二、字母: 0 分: 沒有字母 10 分: 全都是小(大)寫字母 20 ...