Python中使用bidict模块双向字典结构的奇技淫巧


Posted in Python onJuly 12, 2016

快速入门

模块提供三个类来处理一对一映射类型的一些操作
'bidict', 'inverted', 'namedbidict'

>>> import bidict
>>> dir(bidict)
['MutableMapping', '_LEGALNAMEPAT', '_LEGALNAMERE', '__builtins__', '__doc__', '__file__', '__name__', '__package__', 'bidict', 'inverted', 'namedbidict', 're', 'wraps']

1.bidict类: 

>>> from bidict import bidict
>>> D=bidict({'a':'b'})
>>> D['a']
'b'
>>> D[:'b']
'a'
>>> ~D        #反转字典
bidict({'b': 'a'})
>>> dict(D)    #转为普通字典
{'a': 'b'}
>>> D['c']='c'   #添加元素,普通字典的方法都可以用
>>> D
bidict({'a': 'b', 'c': 'c'})

2.inverted类,反转字典的键值

>>> seq = [(1, 'one'), (2, 'two'), (3, 'three')]
>>> list(inverted(seq))
    [('one', 1), ('two', 2), ('three', 3)]

3.namedbidict(mapname, fwdname, invname):

>>> CoupleMap = namedbidict('CoupleMap', 'husbands', 'wives')
>>> famous = CoupleMap({'bill': 'hillary'})
>>> famous.husbands['bill']
'hillary'
>>> famous.wives['hillary']
'bill'
>>> famous.husbands['barack'] = 'michelle'
>>> del famous.wives['hillary']
>>> famous
CoupleMap({'barack': 'michelle'})

更多内容

如果你不喜欢冒号的方式,可以使用namedbidict类给双向字典起2个别名。这样对外会提供正向和逆向的2个子字典。实际上还是以一个双向 字典的形式存在:

>>> HTMLEntities = namedbidict('HTMLEntities', 'names', 'codepoints')
>>> entities = HTMLEntities({'lt': 60, 'gt': 62, 'amp': 38}) # etc
>>> entities.names['lt']
60
>>> entities.codepoints[38]
'amp'

还可以使用一元的逆运算符"~"获取bidict逆映射字典。

>>> import bidict
>>> from bidict import bidict
>>> husbands2wives = bidict({'john': 'jackie'})
>>> ~husbands2wives
bidict({'jackie': 'john'})

以下情况注意添加括号,因为~的优先级低于中括号

>>> import bidict
>>> from bidict import bidict
>>> husbands2wives = bidict({'john': 'jackie'})
>>> ~husbands2wives
bidict({'jackie': 'john'})

以下情况注意添加括号,因为~的优先级低于中括号:

>>> (~bi)['one']
1

bidict不是dict的子类,但它的API的是dict的超集(但没有fromkeys方法,改用了MutableMapping接 口)。

迭代器类inverted会翻转key和value,如:

>>> seq = [(1, 'one'), (2, 'two'), (3, 'three')]
>>> list(inverted(seq))
[('one', 1), ('two', 2), ('three', 3)]

bidict的invert()方法和inverted类似。依赖模块:collections中的MutableMapping,functools中的wraps,re。

bidict可以和字典进行比较

>>> bi == bidict({1:'one'})
>>> bi == dict([(1, 'one')])
True

其他字典通用的方法,bidict也支持:

>>> bi.get('one')
1
>>> bi.setdefault('one', 2)
1
>>> bi.setdefault('two', 2)
2
>>> len(bi) # calls __len__
2
>>> bi.pop('one')
1
>>> bi.popitem()
('two', 2)
>>> bi.inv.setdefault(3, 'three')
'three'
>>> bi
bidict({'three': 3})
>>> [key for key in bi] # calls __iter__, returns keys like dict
['three']
>>> 'three' in bi # calls __contains__
True
>>> list(bi.keys())
['three']
>>> list(bi.values())
[3]
>>> bi.update([('four', 4)])
>>> bi.update({'five': 5}, six=6, seven=7)
>>> sorted(bi.items(), key=lambda x: x[1])
[('three', 3), ('four', 4), ('five', 5), ('six', 6), ('seven', 7)]
Python 相关文章推荐
利用Python实现Windows下的鼠标键盘模拟的实例代码
Jul 13 Python
Python绘制七段数码管实例代码
Dec 20 Python
浅析PHP与Python进行数据交互
May 15 Python
python 计算平均平方误差(MSE)的实例
Jun 29 Python
django自带调试服务器的使用详解
Aug 29 Python
基于python traceback实现异常的获取与处理
Dec 13 Python
python 解决print数组/矩阵无法完整输出的问题
Feb 19 Python
python 下载m3u8视频的示例代码
Nov 11 Python
python中numpy.empty()函数实例讲解
Feb 05 Python
使用Python快速打开一个百万行级别的超大Excel文件的方法
Mar 02 Python
python爬取youtube视频的示例代码
Mar 03 Python
Python 游戏大作炫酷机甲闯关游戏爆肝数千行代码实现案例进阶
Oct 16 Python
Python使用SocketServer模块编写基本服务器程序的教程
Jul 12 #Python
使用Python的Flask框架表单插件Flask-WTF实现Web登录验证
Jul 12 #Python
Python的Flask框架标配模板引擎Jinja2的使用教程
Jul 12 #Python
深度定制Python的Flask框架开发环境的一些技巧总结
Jul 12 #Python
Python的面向对象编程方式学习笔记
Jul 12 #Python
Python使用cookielib模块操作cookie的实例教程
Jul 12 #Python
Python网络编程中urllib2模块的用法总结
Jul 12 #Python
You might like
现磨咖啡骗局!现磨咖啡=新鲜咖啡?现磨咖啡背后的猫腻你不懂!
2019/03/28 冲泡冲煮
一个php作的文本留言本的例子(五)
2006/10/09 PHP
PHP文件下载类
2006/12/06 PHP
CI框架在CLI下执行占用内存过大问题的解决方法
2014/06/17 PHP
PHP动态规划解决0-1背包问题实例分析
2015/03/23 PHP
php类的扩展和继承用法实例
2015/06/20 PHP
Javascript 阻止javascript事件冒泡,获取控件ID值
2009/06/27 Javascript
JS 面向对象的5钟写法
2009/07/31 Javascript
文件编码导致jquery失效的解决方法
2013/06/26 Javascript
jQuery的load()方法及其回调函数用法实例
2015/03/25 Javascript
js获取本机操作系统类型的两种方法
2015/12/19 Javascript
如何通过js实现图片预览功能【附实例代码】
2016/03/30 Javascript
针对JavaScript中this指向的简单理解
2016/08/26 Javascript
js 模仿锚点定位的实现方法
2016/11/19 Javascript
深入理解JavaScript 中的执行上下文和执行栈
2018/10/23 Javascript
Node 搭建一个静态资源服务器的实现
2019/05/20 Javascript
优化Vue项目编译文件大小的方法步骤
2019/05/27 Javascript
javascript实现简易数码时钟
2020/03/30 Javascript
手动实现vue2.0的双向数据绑定原理详解
2021/02/06 Vue.js
[01:05:40]2014 DOTA2国际邀请赛中国区预选赛 5 23 CIS VS DT第三场
2014/05/24 DOTA
[36:02]DOTA2上海特级锦标赛D组小组赛#2 Liquid VS VP第一局
2016/02/28 DOTA
python判断字符串是否纯数字的方法
2014/11/19 Python
Python正则表达式分组概念与用法详解
2017/06/24 Python
Python爬虫框架scrapy实现downloader_middleware设置proxy代理功能示例
2018/08/04 Python
详解python算法之冒泡排序
2019/03/05 Python
Python函数的参数常见分类与用法实例详解
2019/03/30 Python
局域网内python socket实现windows与linux间的消息传送
2019/04/19 Python
Python GUI库Tkiner使用方法代码示例
2020/11/27 Python
python 爬取英雄联盟皮肤并下载的示例
2020/12/04 Python
详解Django关于StreamingHttpResponse与FileResponse文件下载的最优方法
2021/01/07 Python
CSS实现聊天气泡效果
2020/04/26 HTML / CSS
阳光体育活动方案
2014/02/16 职场文书
2014两会学习心得:时代的发展
2014/03/17 职场文书
学雷锋先进个人事迹
2014/05/26 职场文书
常住证明范本
2015/06/23 职场文书
学校学期工作总结
2015/08/13 职场文书