中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python中的set實現不重復的排序原理

發布時間:2020-09-13 08:14:12 來源:腳本之家 閱讀:211 作者:廖Sir 欄目:開發技術

最近在嘗試寫選課系統的時候遇到一個問題:

  1、存在兩個類 School、Teacher ;

  2、School實例中包含多個Teacher的實例,但又不可重復

  本人想到在School中用set()存儲,但是添加Teacher實例的時候做不到去重,后來猜測應該是set會自動調用__eq__方法比較對象是否重復,因此重寫了該方法:

def __eq__(self, other):
  return self.name == other.name

   結果仍然報錯TypeError: unhashable type,如下:

python中的set實現不重復的排序原理

  研究了很久,發現Teacher無法hash的原因是該類中缺少__hash__方法,導致解釋器不知道如何哈希該對象,添加以下代碼后問題解決:

  def __hash__(self):
    return hash(self.name) 

  綜上發現:

  如果想要將對象用set去重,需要重寫__eq__和__hash__兩個方法。

總結

以上所述是小編給大家介紹的python中的set實現不重復的排序原理,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

淳安县| 南京市| 涟源市| 洪泽县| 连州市| 甘孜县| 清苑县| 棋牌| 平利县| 岳阳县| 通许县| 朝阳市| 乌拉特中旗| 美姑县| 齐齐哈尔市| 泉州市| 金昌市| 织金县| 阜平县| 正阳县| 林西县| 石狮市| 册亨县| 隆尧县| 杨浦区| 新巴尔虎右旗| 丁青县| 喀什市| 芮城县| 庐江县| 华安县| 巴中市| 措美县| 原平市| 台东县| 衡阳市| 绍兴市| 乌苏市| 凌云县| 黄大仙区| 五家渠市|