Python中set()函數的去重和篩選作用

一、set()函數的基本概念

在Python中,set()是一種無序且不重複的集合數據類型。使用set()可以輕鬆地去除重複元素,同時可以使用set()進行交集、並集等運算。


# 創建一個set類型
my_set = set([1, 2, 3, 3, 4, 5, 5])
print(my_set) # 輸出{1, 2, 3, 4, 5}

通過set()函數將列錶轉換為集合,即可去除列表中的重複元素。

二、set()函數的去重作用

在實際開發中,往往需要將數據中的重複元素進行去除。set()函數剛好可以勝任此項工作。


# 使用set()去重列表
my_list = [1, 2, 3, 3, 4, 5, 5]
my_set = set(my_list)
new_list = list(my_set)
print(new_list) # 輸出[1, 2, 3, 4, 5]

可以看到,使用set()函數將列表去重之後,再進行轉換為列表,即可得到一個不重複的列表。

三、set()函數的篩選作用

在Python中,我們可以通過判斷語句來進行篩選操作。但是,如果數據量較大,使用判斷語句非常耗費時間和資源。而使用set()函數可以大幅度提升篩選的效率。


# 使用set()篩選列表中符合條件的元素
my_list = [1, 2, 3, 4, 5, 6, 7]
my_filter_set = set([2, 4, 5])
result = set(my_list) & my_filter_set
print(result) # 輸出{2, 4, 5}

以上代碼中,我們使用set()函數將列表和篩選條件轉換成集合類型,然後使用&操作符進行交集運算,即可得到符合條件的元素集合。

四、set()函數的應用場景

set()函數適用於需要進行去重和篩選操作的場景。比如從網站抓取數據進行分析時,很容易抓取到重複的數據,此時使用set()函數將數據去重,然後進行篩選操作,即可得到符合條件的數據。

另外,set()函數還可以用於合併多個列表或集合,如下所示:


# set()函數用於合併多個列表或集合
list1 = [1, 2, 3]
list2 = [2, 3, 4]
list3 = [3, 4, 5]
merged_set = set(list1+list2+list3)
print(merged_set) # 輸出{1, 2, 3, 4, 5}

以上代碼中,我們使用set()函數將三個列表進行合併之後,即可得到合併後的不重複的元素集合。

五、set()函數的應用進階

如果需要對列表中的字典進行去重或篩選操作,可以使用Python的lambda表達式和set()函數的高級特性。


# 使用lambda表達式和高級特性對字典進行去重操作
my_list = [{'name': 'Tom', 'age': 22}, {'name': 'Bob', 'age': 28}, 
           {'name': 'Tom', 'age': 22}, {'name': 'Lisa', 'age': 32}]
new_list = list(set([frozenset(d.items()) for d in my_list]))
result = [dict(elem) for elem in new_list]
print(result) # 輸出[{'name': 'Lisa', 'age': 32}, {'name': 'Bob', 'age': 28}, {'name': 'Tom', 'age': 22}]

以上代碼中,我們使用frozenset()將字典的鍵值對轉換為不可變集合,然後使用set()函數進行去重操作。最後,還原字典格式,即可得到去重後的字典列表。

六、總結

set()函數是Python中一個非常實用的函數,它可以輕鬆地實現去重和篩選操作,同時也可以用於合併多個列表或集合。在實際開發中,可以結合lambda表達式和高級特性進行更加複雜的操作。

使用set()函數可以大幅度提升代碼的效率和性能,是Python工程師開發過程中不可或缺的工具。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/305210.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2025-01-01 11:06
下一篇 2025-01-01 11:07

相關推薦

  • Python計算陽曆日期對應周幾

    本文介紹如何通過Python計算任意陽曆日期對應周幾。 一、獲取日期 獲取日期可以通過Python內置的模塊datetime實現,示例代碼如下: from datetime imp…

    編程 2025-04-29
  • 如何查看Anaconda中Python路徑

    對Anaconda中Python路徑即conda環境的查看進行詳細的闡述。 一、使用命令行查看 1、在Windows系統中,可以使用命令提示符(cmd)或者Anaconda Pro…

    編程 2025-04-29
  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python列表中負數的個數

    Python列表是一個有序的集合,可以存儲多個不同類型的元素。而負數是指小於0的整數。在Python列表中,我們想要找到負數的個數,可以通過以下幾個方面進行實現。 一、使用循環遍歷…

    編程 2025-04-29
  • Python周杰倫代碼用法介紹

    本文將從多個方面對Python周杰倫代碼進行詳細的闡述。 一、代碼介紹 from urllib.request import urlopen from bs4 import Bea…

    編程 2025-04-29
  • Python字典去重複工具

    使用Python語言編寫字典去重複工具,可幫助用戶快速去重複。 一、字典去重複工具的需求 在使用Python編寫程序時,我們經常需要處理數據文件,其中包含了大量的重複數據。為了方便…

    編程 2025-04-29
  • Python編程二級證書考試相關現已可以上網購買

    計算機二級Python考試是一項重要的國家級認證考試,也是Python編程的入門考試。與其他考試一樣,Python編程二級證書的考生需要進入正式考試,而為了備考,這篇文章將詳細介紹…

    編程 2025-04-29
  • Python字符串寬度不限制怎麼打代碼

    本文將為大家詳細介紹Python字符串寬度不限制時如何打代碼的幾個方面。 一、保持代碼風格的統一 在Python字符串寬度不限制的情況下,我們可以寫出很長很長的一行代碼。但是,為了…

    編程 2025-04-29
  • 蝴蝶優化算法Python版

    蝴蝶優化算法是一種基於仿生學的優化算法,模仿自然界中的蝴蝶進行搜索。它可以應用於多個領域的優化問題,包括數學優化、工程問題、機器學習等。本文將從多個方面對蝴蝶優化算法Python版…

    編程 2025-04-29
  • Python讀取CSV數據畫散點圖

    本文將從以下方面詳細闡述Python讀取CSV文件並畫出散點圖的方法: 一、CSV文件介紹 CSV(Comma-Separated Values)即逗號分隔值,是一種存儲表格數據的…

    編程 2025-04-29

發表回復

登錄後才能評論