Python中的内置类型是我们开发中最常见的,很多人都能熟练的使用它们。
然而有一些内置类型确实不那么常见的,或者说往往会被我们忽略,所以这次的主题就是带领大家重新认识这些“不同寻常”的内置类型。
(注意:本文基于python3,不会包含任何python2相关内容)
frozenset
不可变集合(frozenset)与普通的set一样,只不过它的元素是不可变的,因此诸如`add`,`remove`,`update`等可以添加/删除/改变集合内元素的方法是不存在的,换句话说一旦frozenset建立后你将不再可能更改集合内的元素。其他的方法与set一致: ```python > frozen = frozenset([1, 1, 2, 3, 4, 5, 6, 6]) frozenset({1, 2, 3, 4, 5, 6}) > frozen | {1, 2, 3, 7, 8} frozenset({1, 2, 3, 4, 5, 6, 7, 8}) > frozen ^ {1, 2, 3, 7, 8} frozenset({4, 5, 6, 7, 8}) ```
range
`range`事实上相当得常见,所以你也许会奇怪我为什么把它列出来。
其实原因很简单,因为大部分人熟悉range
的使用,但并不清楚range
到底是什么。返回迭代器?返回一个可迭代对象?range本身又是什么呢?
答案揭晓:
> range <class 'range'>
是的,range
是个class!所以当我们使用for i in range(1, 10)
这样的代码时,实际上我们遍历了一个range
对象,而range
也实现了可迭代对象需要的__iter__
魔法方法,所以它自身是可迭代对象:
> range.__iter__ <slot wrapper '__iter__' of 'range' objects>
因此,range
既不返回迭代器,也不返回其他可迭代对象,而是返回的自己。
bytearray
`bytearray`一般情况下并不常见,它主要为了可以实现原地修改bytes对象而出现,因为bytes和str一样是不可变对象,例如这样是非法的: ```python > b = '测试用例a'.encode('utf8') > b[-1] = 98 # change 'a' -> 'b' Traceback (most recent call last): File "", line 1, in TypeError: 'bytes' object does not support item assignment ``` 而当我们把bytes的内容复制给`bytearray`时就可以进行原地修改了: ```python > array = bytearray(b) > array[-1] = 98 > array.decode('utf8') 测试用例b ``` `bytearray`对象没有字面常量,因此只能通过构造函数创建,它有着和bytes一样的方法,只是可变以及多了一些序列对象的特性。如果要创建一个`bytearray`可以有如下的几种方法: - `bytearray()`返回一个空的`bytearray`对象 - `bytearray(10)`创建一个长度为10且内容被0填充的`bytearray` - `bytearray(iterable)`会将可迭代对象的内容转换成bytes然后存入对象中 - `bytearray(b'Hi!')`将已有的二进制数据复制进对象
另外bytearray
还提供了fromhex
和hex
方便将数据以16进制的形式输入输出:
> array.hex() 'e6b58be8af95e794a8e4be8b62' > bytearray().fromhex('e6b58be8af95e794a8e4be8b62').decode('utf8') '测试用例b'
memoryview
`memoryview`提供了直接访问对象内存的机制,只要目标对象支持[buffer protocol](https://docs.python.org/3/c-api/buffer.html#bufferobjects),例如`bytes`和`bytearray`。
memoryview
有个称为“元素”的概念,也就是对象规定的最小的内存单元,比如bytes
和bytearray
的最小内存单元就是一个byte,具体取决于对象的实现。
len(view)
通常等于len(view.tolist())
,也就是等于view的“元素”数量。如果view.ndim == 0
,那么整个view的内存会被视作一个整体,len会返回1,如果view.ndim == 1
那么就正常返回“元素”的个数。view.itemsize会返回单个“元素”的大小。单位是byte。
view.readonly
表示当前的memoryview
是否是只读的,例如bytes对象的view就是只读的,view.readonly
的值为True
。是否只读取决于被引用的对象是否可变以及对buffer protocol的实现。
对于使用完毕的memoryview应该尽快调用其release()方法释放资源,而且部分对象在被view引用时会自动进行一些限制,比如bytearray
会禁止调整大小,及时释放view是资源可以解除这些限制。
结合示例可以更清晰地了解这些特性:
> data = bytearray(b'abcefg') > v = memoryview(data) > v.readonly False > v[0] = ord(b'z') > data bytearray(b'zbcefg') > v[1:4] = b'123' > data bytearray(b'z123fg') > v[2:3] = b'spam' Traceback (most recent call last): File "<stdin>", line 1, in <module> ValueError: memoryview assignment: lvalue and rvalue have different structures > v[2:6] = b'spam' > data bytearray(b'z1spam')
dict-views
准确的说,这不是一种类型,而是一种概念。然而typing里仍然将其视为一种类型,所以也就罗列在此了。
概念:返回自dict.keys()
,dict.values()
和dict.items()
的对象被称作dict-views。
对于views对象,可以使用len,成员检测,它本身也是可迭代对象:
> dishes = {'eggs': 2, 'sausage': 1, 'bacon': 1, 'spam': 500} > keys = dishes.keys() > values = dishes.values() > # iteration > n = 0 > for val in values: ... n += val > print(n) 504 > # keys and values are iterated over in the same order (insertion order) > list(keys) ['eggs', 'sausage', 'bacon', 'spam'] > list(values) [2, 1, 1, 500] > # view objects are dynamic and reflect dict changes > del dishes['eggs'] > del dishes['sausage'] > list(keys) ['bacon', 'spam'] > # set operations > keys & {'eggs', 'bacon', 'salad'} {'bacon'} > keys ^ {'sausage', 'juice'} {'juice', 'sausage', 'bacon', 'spam'}
从例子中可以看出,views保持着元素的插入顺序(插入顺序的保证从python3.6开始)以及views动态反应了key/value的插入和删除以及修改,因此在某些场景下views对象是相当有用的。
The Ellipsis Object (...)
`...`不是一个类型,不过算是一个内置对象。
它没什么特殊的含义,仅表示省略,通常被用在type hints中:
> ... Ellipsis > from typing import Callable > func: Callable[..., None] = lambda x,y:print(x*y)
func是一个没有返回值的函数,参数列表没有做任何限制。
你也可以写成Ellipsis
,两者是等价的,不过显然是...这种形式更简单明了。
以上就是这些容易被忽略和遗忘的内置类型,如有错误和疏漏欢迎指出。
参考:
https://docs.python.org/3/library/stdtypes.html
https://docs.python.org/3/c-api/buffer.html#bufferobjects
以上就是容易被忽略的Python内置类型的详细内容,更多关于Python内置类型的资料请关注其它相关文章!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]