Python对象比较与排序_集合使用说明【指导】
技术百科
冷漠man
发布时间:2026-01-01
浏览: 次 Python中对象比较与排序需区分值相等(==,调用__eq__)和同一性(is,比较id);sorted()返回新列表,list.sort()原地排序;set无序不可排序,去重后需转list再排序。
Python中对象的比较与排序,核心在于明确“值相等”和“顺序大小”的区别;集合(set)本身无序且不支持排序,但可与其他数据结构配合实现去重、交并差等逻辑。关键不是硬套规则,而是理解底层机制再选合适工具。
对象比较:== 与 is 的本质区别
== 判断两个对象的值是否相等,调用的是 __eq__ 方法;is 判断是否为同一内存对象(即 id 是否相同)。自定义类若未重写 __eq__,默认行为等同于 is。
- 字符串、数字等不可变类型,小范围整数(-5 到 256)和短字符串可能被缓存,导致 is 偶尔返回 True,但这不是规范保证,切勿依赖
- 列表、字典、自定义实例默认 == 比较内容(递归),但 is 几乎总为 False,除非显式赋值引用同一对象
- 需自定义比较逻辑时,在类中实现 __eq__(和 __hash__ 若需放入 set/dict)
排序基础:sorted() 与 list.sort()
sorted() 返回新列表,原对象不变;list.sort() 就地排序,返回 None。两者都接受 key 参数指定排序依据,reverse 控制升/降序。
- key 应为函数,接收单个元素,返回用于比较的值。例如 sorted(data, key=lambda x: x.name) 按 name 属性排
- 若元素本身不支持直接比较(如含 None、混合类型或自定义对象无 __lt__),必须提供 key,否则报 TypeError
- 稳定排序:相同 key 值的元素保持原有相对顺序,Python 的 sort 保证稳定
集合(set)的正确使用场景
set 是无序
、唯一、可变的哈希容器,不支持索引、切片或排序操作。它适合快速查重、成员判断、集合运算,而非存储有序数据。
- 创建:s = {1, 2, 3} 或 s = set([1, 2, 3]);空集合只能用 set(),{} 是空字典
- 常见操作:s.add(x)、s.discard(x)(不存在不报错)、s.remove(x)(不存在报错)、s.pop()(随机删一个)
- 集合运算:s1 & s2(交集)、s1 | s2(并集)、s1 - s2(差集)、s1 ^ s2(对称差);也可用方法形式如 s1.intersection(s2)
- 若需“去重后排序”,先转 list 再 sorted(list(s)),不要试图对 set 排序
混合使用:排序 + 集合去重的典型组合
实际开发常需“去重后按某规则排序”。此时应分两步:先用 set 或 dict.fromkeys() 去重(保持插入顺序可用 dict.fromkeys(lst).keys()),再排序。
- 例:对用户列表按年龄去重(同名同龄算重复)后按分数降序:sorted(set(users), key=lambda u: u.score, reverse=True)
- 注意:set(users) 要求 users 中对象已实现 __eq__ 和 __hash__,否则报错;更稳妥做法是提取关键字段构造 frozenset 或 tuple 去重
- 大数据量时,用 set 记录已见 key(如 name),遍历原列表筛选,再排序,避免全量构造中间集合
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- Windows电脑键盘突然失灵怎么办?(驱动与硬件
- 如何使用Golang benchmark测量函数延
- 如何用列表一次性对 DataFrame 的指定列应
- Win11如何关闭游戏模式 Win11禁用Xbox
- Win11怎么看电池循环次数_Win11笔记本电池
- 如何使用Golang管理跨项目依赖_Golang多
- 如何在Golang中处理数据库事务错误_回滚和日志
- windows如何修改文件默认打开方式_windo
- Python 中将 ISO 8601 时间戳转换为
- 如何在Golang中捕获JSON序列化错误_Gol
- php订单日志怎么记录评价_php记录订单评价日志
- Win10如何卸载预装Edge扩展_Win10卸载
- Win11怎么修改DNS服务器 Win11设置DN
- Python抽象类与接口设计_规范说明【指导】
- Win11怎么关闭定位服务_保护Win11位置隐私
- php怎么捕获异常_trycatch结构处理运行时
- 如何使用Golang实现容器安全扫描_Golang
- Drupal 中 HTML 链接被双重转义导致渲染
- PHP中require语句后直接调用返回对象方法的
- Win11怎么清理C盘下载文件夹_Win11清理下
- Win11右键反应慢怎么办 Win11优化右键菜单
- Win10怎样卸载DockerDesktop_Wi
- Windows10无法识别USB设备描述符请求失败
- 如何诊断并终止卡死的 multiprocessin
- 如何在Golang中使用replace替换模块_指
- Linux怎么实现内网穿透_Linux安装Frp客
- 如何在 PHP 单元测试中正确模拟带方法的图像处理
- Win11怎么忘记WiFi网络_Win11删除已保
- php嵌入式需要什么环境_搭建php+linux嵌
- c# 如何深拷贝和浅拷贝
- 如何在Golang中引入测试模块_Golang测试
- Win11怎样安装钉钉客户端_Win11安装钉钉教
- Win11怎么设置桌面图标间距_Windows11
- 如何在Golang中理解指针比较_Golang地址
- windows如何禁用驱动程序强制签名_windo
- Win11快速助手怎么用_Win11远程协助连接教
- VSC里PHP变量未定义报错怎么解决_错误抑制技巧
- c++中的CRTP是什么 c++奇异递归模板模式【
- Win11怎么关闭通知消息_屏蔽Windows 1
- Win11怎么设置默认邮件客户端 Win11修改M
- 为什么Go需要go mod文件_Go go mod
- Win11摄像头无法使用怎么办_Win11相机隐私
- Python高性能计算项目教程_NumPyCyth
- Windows 11怎么设置默认解压软件_Wind
- c++怎么编写动态链接库dll_c++ __dec
- Win11任务栏怎么放到顶部_Win11修改任务栏
- 当网站SEO排名下降时,如何应对?
- Win11怎么设置系统还原_Windows11系统
- 如何使用Golang管理模块版本_Golanggo
- Linux怎么修改用户密码_Linux系统pass

QQ客服