通过实现__getitem__、__setitem__、__delitem__、__contains__、__iter__和__len__方法,可使自定义类模拟字典行为,支持键访问、赋值、删除、成员检测、迭代与长度计算,如MyDict示例所示。

python 中字典(dict)的底层行为由一系列“魔法方法”控制,这些方法以双下划线开头和结尾,也称为“特殊方法”或“dunder 方法”。当我们自定义类并希望模拟字典的行为时,可以通过实现这些方法来让对象像 dict 一样工作。
__getitem__
这个方法用于实现通过键访问值的操作,比如 d[‘key’]。
当你执行 obj[key] 时,Python 会自动调用 __getitem__(key)。
示例:
<pre class="brush:php;toolbar:false;"> class MyDict: def __init__(self): self.data = {} def __getitem__(self, key): return self.data[key] <p>d = MyDict() d.data['name'] = 'Alice' print(d['name']) # 输出: Alice</p>
__setitem__
用于实现设置键值对的操作,例如 d[‘key’] = value。
立即学习“Python免费学习笔记(深入)”;
当执行 obj[key] = value 时,Python 调用 __setitem__(key, value)。
更新上面的例子:
<pre class="brush:php;toolbar:false;"> def __setitem__(self, key, value): self.data[key] = value <p>d['age'] = 25 # 调用 <strong>setitem</strong></p>
__delitem__
对应方法是 __delitem__(key)。
例如:
<pre class="brush:php;toolbar:false;"> def __delitem__(self, key): del self.data[key] <p>del d['age'] # 调用 <strong>delitem</strong></p> <div class="aritcle_card"> <a class="aritcle_card_img" href="/ai/%E6%B3%95%E8%AF%AD%E5%86%99%E4%BD%9C%E5%8A%A9%E6%89%8B"> <img src="https://img.php.cn/upload/ai_manual/000/000/000/175680203955338.png" alt="法语写作助手"> </a> <div class="aritcle_card_info"> <a href="/ai/%E6%B3%95%E8%AF%AD%E5%86%99%E4%BD%9C%E5%8A%A9%E6%89%8B">法语写作助手</a> <p>法语助手旗下的AI智能写作平台,支持语法、拼写自动纠错,一键改写、润色你的法语作文。</p> <div class=""> <img src="/static/images/card_xiazai.png" alt="法语写作助手"> <span>31</span> </div> </div> <a href="/ai/%E6%B3%95%E8%AF%AD%E5%86%99%E4%BD%9C%E5%8A%A9%E6%89%8B" class="aritcle_card_btn"> <span>查看详情</span> <img src="/static/images/cardxiayige-3.png" alt="法语写作助手"> </a> </div>
__contains__
控制 key in obj 的行为。
默认情况下,如果实现了 __getitem__,Python 可能通过捕获异常判断是否存在,但显式实现更高效、清晰。
示例:
<pre class="brush:php;toolbar:false;"> def __contains__(self, key): return key in self.data <p>print('name' in d) # True</p>
__iter__ 和 __len__
让自定义字典支持迭代和 len() 函数。
- __iter__:返回一个可迭代对象,通常 yield 键
- __len__:返回键值对的数量
实现:
<pre class="brush:php;toolbar:false;"> def __iter__(self): return iter(self.data) <p>def <strong>len</strong>(self): return len(self.data)</p><p>for k in d: # 可迭代 print(k)</p><p>print(len(d)) # 输出长度</p>
其他相关方法(可选)
虽然不是必须,但完整模拟 dict 行为时可以考虑:
基本上就这些。通过实现 __getitem__、__setitem__、__delitem__、__contains__、__iter__ 和 __len__,你就能创建一个行为接近原生 dict 的类。不复杂但容易忽略细节。