Python3 自定義比較排序 運算子

2021-08-30 19:22:37 字數 2771 閱讀 8455

python3和python2相比有挺多變化。

在python2中可以直接寫乙個cmp函式作為引數傳入sort來自定義排序,但是python3取消了。

在這裡總結一下python3的自定義排序的兩種寫法,歡迎補充。

我們以二維空間中的點來作為待排序的資料結構,我們希望能先比較x後再比較y。

class pos:

def __init__(self, x = 0, y = 0):

self.x = x

self.y = y

def __str__(self):

return ('(%s, %s)' % (self.x, self.y))

__repr__ = __str__

第一種方法我們還是以重寫cmp或lambda表示式的形式,和python2很類似

注意,此方法用sorted是不能成功排序的

只是要借助functools

import functools

def cmp(a, b):

return a.x-b.x if a.x != b.x else a.y-b.y # x y均按照從小到大的順序

if __name__ == '__main__':

test_list = [pos(5, 1), pos(2,5), pos(2, 4)]

# test_list.sort(key=functools.cmp_to_key(lambda a,b: a.x-b.x if a.x != b.x else a.y-b.y))

test_list.sort(key=functools.cmp_to_key(cmp))

# sorted(test_list, key=functools.cmp_to_key(cmp)) # 親測此方法不能成功排序

print(test_list) # 輸出結果 [(2, 4), (2, 5), (5, 1)]

python2中可以直接重寫__cmp__方法來實現比較,但是python3中已經取消了.

python3中需要細分每乙個比較運算子.

__lt__: <

__gt__: >

__ge__: >=

__eq__: ==

__le__: <=

實現如下

class pos:

def __init__(self, x = 0, y = 0):

self.x = x

self.y = y

def __str__(self):

return ('(%s, %s)' % (self.x, self.y))

def __lt__(self, other):

print('lt: ' + str(self))

return self.x < other.x if self.x != other.x else self.y < other.y

def __gt__(self, other):

print('gt: ' + str(self))

return self.x > other.x if self.x != other.x else self.y > other.y

def __ge__(self, other):

print('ge: ' + str(self))

return self.x >= other.x if self.x != other.x else self.y >= other.y

def __eq__(self, other):

print('eq: ' + str(self))

return self.x == other.x and self.y == other.y

def __le__(self, other):

print('le: ' + str(self))

return self.x <= other.x if self.x != other.x else self.y <= other.y

__repr__ = __str__

我們實踐一下

if __name__ == '__main__':

if pos(5,1) <= pos(2,4):

print('true!')

if pos(5,1) == pos(2,4):

print('true!')

if pos(5,1) > pos(2,4):

print('true!')

# 輸出

# le: (5, 1)

# eq: (5, 1)

# gt: (5, 1)

# true!

最後我們回到排序

if __name__ == '__main__':

test_list = [pos(5, 1), pos(2,5), pos(2, 4)]

test_list.sort()

print(test_list)

test_list.sort(reverse=true)

print(test_list)

# 輸出

# lt: (2, 5)

# lt: (2, 4)

# [(2, 4), (2, 5), (5, 1)]

# lt: (2, 5)

# lt: (2, 4)

# [(5, 1), (2, 5), (2, 4)]

python3 自定義比較函式

python 2 中支援類似 c 中 cmp 的寫法 python 3 放棄了這一用法 官方說明 所以不想寫lambda的話,加一句cmp to key 就行了 def 比較函式 return 原來的方式是 sorted cmp 比較函式 現在的方式是 from functools import c...

python3 自定義比較器

摘要 在一些場景中,需要重新對已有的資料排序,可能所給出的資料型別或者資料數量較多,需要給定排序規則。import functools def by score t1,t2 if t1 0 t2 0 return 1 elif t1 0 t2 1 return 1 elif t1 1 t2 1 re...

python3自定義函式

一 什麼是函式 函式是組織好的,可重複使用的,用來實現單一,或相關聯功能的 段。函式能提高應用的模組性,和 的重複利用率。你已經知道python提供了許多內建函式,比如print 但你也可以自己建立函式,這被叫做使用者自定義函式。語法def 函式名 引數列表 函式體def func print 王小...