python3.5中cmp怎么用

Python 3.5 中 cmp() 函数已被彻底移除,应使用比较运算符或 functools.cmp_to_key() 替代;自定义排序优先用 key 参数,类比较需实现 lt__、__eq 等富比较方法。

Python 3.5 中 没有 cmp() 函数,它在 Python 3.0 就被彻底移除了。

官方明确说明:cmp() 函数应被视为“已消失”,__cmp__() 特殊方法也不再支持。

所以你不能直接写 cmp(a, b),会报错:

>>> cmp(1, 2)
NameError: name 'cmp' is not found

替代方案:用比较运算符或 functools.cmp_to_key

✅ 推荐方式:用 functools.cmp_to_key() 配合 sorted()list.sort()

如果你原本想用 cmp 做自定义排序(比如按绝对值、按字符串长度、按多条件),现在要改写成「返回布尔逻辑」的 key 函数,或用 cmp_to_key 包装旧式比较逻辑。

例如,按绝对值升序排序:

from functools import cmp_to_key

def my_cmp(x, y):
    if abs(x) < abs(y):
        return -1
    elif abs(x) == abs(y):
        return 0
    else:
        return 1

nums = [-5, 3, -1, 4]
sorted_nums = sorted(nums, key=cmp_to_key(my_cmp))
print(sorted_nums)  # [-1, 3, 4, -5]

⚠️ 注意:你的 my_cmp 函数语义要和老 cmp() 一致 —— 返回 -1 / 0 / 1

✅ 更简洁的方式:优先用 key 参数(不用 cmp)

大多数场景其实不需要写比较函数,直接用 key 更清晰:

# 按长度排序字符串
words = ['hi', 'hello', 'a']
words.sort(key=len)  # ['a', 'hi', 'hello']

# 按第二项排序元组
pairs = [('x', 3), ('y', 1), ('z', 2)]
sorted_pairs = sorted(pairs, key=lambda x: x[1])  # [('y', 1), ('z', 2), ('x', 3)]

❌ 不要用 __cmp__ 方法

Python 3 已废弃 __cmp__。自定义类比较应实现富比较方法,如:

class Person:
    def __init__(self, name, age):
        self.name = name
        self.age = age

    def __lt__(self, other):  # 支持 <
        return self.age < other.age

    def __eq__(self, other):  # 支持 ==
        return self.age == other.age

这样就能用于 sorted()min() 等函数。


补充:为什么删掉 cmp()

  • 容易混淆(返回 -1/0/1,而不是布尔值)
  • key 参数更直观、高效、可读性更强
  • 富比较方法(__lt__, __eq__ 等)让对象行为更明确、更符合直觉

基本上就这些。不复杂但容易忽略:Python 3 里真没 cmp(),别找它了,用 keycmp_to_key 就对了。