python 如何判断两个字典是否相等

Python中判断字典相等直接用==即可,它深度比较键值(顺序无关、支持嵌套);is仅判断同一对象;需严格类型区分或浮点容差时须自定义逻辑。

Python 中判断两个字典是否相等,直接用 == 运算符即可。它会自动比较键、值是否完全相同(包括嵌套结构),无需手动遍历。

基础判断:用 == 就够了

Python 字典的 == 是深度比较:

  • 要求所有键完全一致(顺序无关)
  • 每个键对应的值也必须相等(支持嵌套字典、列表等)
  • 类型不同但值等价(如 1 == True)也会返回 True,这是 Python 的常规比较规则

示例

dict1 = {'a': 1, 'b': [2, 3]}
dict2 = {'b': [2, 3], 'a': 1}
print(dict1 == dict2)  # True,键顺序不影响

注意:is 判断的是同一对象,不是内容相等

is 检查的是内存地址是否相同,和“内容相等”无关:

  • 即使两个字典内容一模一样,dict1 is dict2 通常为 False(除非是同一个对象引用)
  • 仅在确认是否为同一实例时才用 is,比如检查是否为 None

需要严格类型区分?手动逐项比对

如果希望 1True 被视为不等(即禁用隐式类型转换),可自定义比较逻辑:

  • 先检查类型是否都是 dict
  • 再检查键集合是否相等:dict1.keys() == dict2.keys()
  • 对每个键,用 istype() + == 检查值是否类型和内容都一致

简单示例(忽略嵌套):

def strict_dict_equal(d1, d2):
    if not isinstance(d1, dict) or not isinstance(d2, dict):
        return False
    if d1.keys() != d2.keys():
        return False
    return all(type(d1[k]) == type(d2[k]) and d1[k] == d2[k] for k in d1)

含浮点数或精度敏感场景?考虑容差比较

若字典中含浮点数,直接 == 可能因精度问题失败:

  • math.isclose() 替代 == 比较数值
  • 需递归处理嵌套结构,或借助第三方库如 deepdiff

例如:

import math
def float_aware_equal(d1, d2, rel_tol=1e-9):
    if d1.keys() != d2.keys():
        return False
    for k in d1:
        v1, v2 = d1[k], d2[k]
        if isinstance(v1, float) and isinstance(v2, float):
            if not math.isclose(v1, v2, rel_tol=rel_tol):
                return False
        elif v1 != v2:
            return False
    return True