首页 > 编程语言 >Python中的集合魔法:解锁高效数据处理的秘密

Python中的集合魔法:解锁高效数据处理的秘密

时间:2024-09-02 22:24:22浏览次数:11  
标签:interests 元素 Python items 解锁 魔法 set user 集合

引言

集合是一种不允许重复元素的数据结构,并且其内部元素无序排列。这种特性使得集合在某些场景下表现得极为出色:

  • 去重:快速去除列表或数组中的重复项。
    • 交集、并集、差集等运算:用于比较两个或多个集合间的关系,非常适用于权限控制、用户管理等领域。
    • 性能优势:相较于列表,集合在查找元素时速度更快,平均时间复杂度为O(1)。

基础语法介绍

创建集合

在Python中创建一个空集合需要使用set()函数,而直接使用花括号 {} 会创建一个空字典而不是空集合。若想创建含有初始元素的集合,则可以直接将这些元素放入花括号内:

# 创建空集合
empty_set = set()

# 创建非空集合
fruits = {'apple', 'banana', 'cherry'}

基本操作

集合支持添加、删除元素以及判断元素是否存在于集合中等操作:

# 添加元素
fruits.add('orange')

# 删除元素
fruits.remove('banana')  # 若元素不存在会抛出KeyError异常

# 判断元素是否存在
print('apple' in fruits)  # 输出 True 或 False

基础实例

假设我们需要从一个学生名单中找出所有姓“张”的同学,可以利用集合来简化这个任务:

students = ['张三', '李四', '王五', '张六']
zhangs = {name for name in students if name.startswith('张')}
print(zhangs)  # 输出 {'张三', '张六'}

进阶实例

在处理更复杂的业务逻辑时,集合同样能发挥巨大作用。例如,在实现好友推荐系统时,可以通过计算用户之间的共同兴趣点来推荐新朋友:

def recommend_friends(user_interests, all_users):
    user_set = set(user_interests[user])
    recommended = []
    for u in all_users:
        if u != user:  # 不推荐自己
            other_interests = set(user_interests[u])
            common_interests = user_set & other_interests  # 交集
            if len(common_interests) > 0:
                recommended.append((u, len(common_interests)))
    return sorted(recommended, key=lambda x: x[1], reverse=True)

# 示例数据
user_interests = {
    'Alice': ['Music', 'Art', 'Travel'],
    'Bob': ['Sports', 'Cooking', 'Travel'],
    ...
}

实战案例

在某电商网站后台管理系统中,我们面临一个挑战:如何快速定位哪些商品既属于热销商品又属于库存紧张的商品?通过集合操作,这个问题变得迎刃而解:

hot_items = {'item1', 'item2', 'item3'}
low_stock_items = {'item2', 'item3', 'item4'}

# 找出同时满足条件的商品
critical_items = hot_items & low_stock_items
print(critical_items)  # 输出 {'item2', 'item3'}

扩展讨论

除了上述介绍的基本功能外,Python还提供了更多与集合相关的高级特性,比如frozenset,它是一个不可变版本的集合类型,非常适合用于作为字典的键或者作为其他集合的元素。此外,集合还支持数学中的对称差集运算(^),即两个集合中独有的元素组成的集合。

标签:interests,元素,Python,items,解锁,魔法,set,user,集合
From: https://blog.51cto.com/u_16918694/11900960

相关文章

  • Python机器学习:基础、算法与实战
    1:《Python机器学习:基础算法与实战》内容简介本书基于 Python 语言,结合实际的数据集,介绍了机器学习算法以及数据分析方法的应用。本书主要包含两部分内容,第一部分为 Python 机器学习入门知识:主要介绍了 Python 基础内容、Numpy与Pandas 库数据操作、Matplotlib 与Seaborn......
  • Python中的函数艺术:解锁高效编程的秘密
    引言在软件开发过程中,重复使用相同的代码段是不可避免的。这不仅增加了代码量,还可能导致维护困难。通过定义函数,我们可以将这些重复代码抽象出来,封装成一个可重用的组件。这样做的好处显而易见:减少了代码冗余、提高了代码的复用性,同时也使得程序结构更加清晰。此外,在团队协作时,良......
  • Python机器学习:基础算法与实战-内容介绍
    1:《Python机器学习:基础算法与实战》内容简介本书基于 Python 语言,结合实际的数据集,介绍了机器学习算法以及数据分析方法的应用。本书主要包含两部分内容,第一部分为 Python 机器学习入门知识:主要介绍了 Python 基础内容、Numpy与Pandas 库数据操作、Matplotlib 与Seaborn......
  • 中望CAD 专业 v2024 解锁版下载与安装教程 (CAD三维制图)
    安装步骤ZWCAD2024-SP1.3-x64-Chs-Setup+Crack:ZWCAD2024-SP1.3-x64-Chs-Setup+Crack.zip1、下载解压后点击如下进行安装2、选择安装目录,最好不要安装在系统盘(C盘)3、安装中...耐心等待2-3分钟4、安装完先不要运行它,点击完成即可5、回到我们解压的文件夹里面,访问crack文件......
  • Python 实现行为驱动开发 (BDD) 自动化测试详解
    什么是BDD?行为驱动开发(BDD,Behavior-DrivenDevelopment)是一种软件开发过程,旨在通过鼓励协作和沟通,提高软件质量。BDD的核心理念是用自然语言描述软件的行为,使得业务人员、开发人员和测试人员都能参与其中。BDD是由测试驱动开发(TDD,Test-DrivenDevelopment)演......
  • 2024.9.2 Python,用栈写每日温度,等差数列划分,子串所有可能性,等差数列划分,深度优先搜索
    1.每日温度给定一个整数数组temperatures,表示每天的温度,返回一个数组answer,其中answer[i]是指对于第i天,下一个更高温度出现在几天后。如果气温在这之后都不会升高,请在该位置用0来代替。示例1:输入:temperatures=[73,74,75,71,69,72,76,73]输出:[1,1,4,2,......
  • Python Web应用程序构建的最佳实践(代码实例与深度解析)
    在当今数字时代,构建高效、可扩展的Web应用程序是开发者们的一项重要任务。Python,作为一种简洁、强大的编程语言,为Web开发提供了丰富的工具和框架。在本篇文章中,我们将探讨使用Python构建Web应用程序的最佳实践,通过代码实例和深度解析来帮助你更好地理解和运用这些技术。1.选择合适......
  • python画三角函数图像tanx
    源码#开发者:a_blue_fat#日期:2024/8/14#时间:19:00#文件名称三角函数画图#开发者a_blue_fat#日期2024年8月9日importmathimportturtleastfrom三角函数得数importcos,sin,tant.setup(1000,800,0,0)#将画画点移动到指定位置写入需要标记数......
  • 无魔法利用GPT4o-mini改善网页翻译
    步骤浏览器安装沉浸式翻译插件:https://immersivetranslate.com/进入伊莉思AGI网址:https://agi.ylsap.com/,创建账号并进入个人中心创建并复制APIKEY进入沉浸式翻译插件设置按如下设置展开更多选项https://api.ylsagi.io/tolinks/v2/translators/chat/completions测试......
  • 【Python】企业排名、地域分布与词云分析可视化
    目录数据处理Pyecharts各国数量分布地图数量占比城市分布营业收入利润转化数据处理2021世界五百强企业数据,包含公司名称、公司链接、营业收入(百万美元)、利润(百万美元)、国家等信息。数据集下载:Python企业排名、地域分布与词云分析数据集资源-CSDN文库importnu......