容易被忽略的Python内置类型


Posted in Python onSeptember 03, 2020

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还提供了fromhexhex方便将数据以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有个称为“元素”的概念,也就是对象规定的最小的内存单元,比如bytesbytearray的最小内存单元就是一个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内置类型的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
python使用rsa加密算法模块模拟新浪微博登录
Jan 22 Python
python处理文本文件实现生成指定格式文件的方法
Jul 31 Python
安装Python的web.py框架并从hello world开始编程
Apr 25 Python
python和shell获取文本内容的方法
Jun 05 Python
使用Python+wxpy 找出微信里把你删除的好友实例
Feb 21 Python
django多文件上传,form提交,多对多外键保存的实例
Aug 06 Python
Python3从零开始搭建一个语音对话机器人的实现
Aug 23 Python
结合OpenCV与TensorFlow进行人脸识别的实现
Oct 10 Python
python列表推导和生成器表达式知识点总结
Jan 10 Python
Python+PyQt5+MySQL实现天气管理系统
Jun 16 Python
Python jieba库分词模式实例用法
Jan 13 Python
python设置 matplotlib 正确显示中文的四种方式
May 10 Python
python类共享变量操作
Sep 03 #Python
Python pip install之SSL异常处理操作
Sep 03 #Python
详解python tkinter 图片插入问题
Sep 03 #Python
解决PyCharm IDE环境下,执行unittest不生成测试报告的问题
Sep 03 #Python
PyTorch中Tensor的数据类型和运算的使用
Sep 03 #Python
python开发入门——set的使用
Sep 03 #Python
使用anaconda安装pytorch的实现步骤
Sep 03 #Python
You might like
用PHP和ACCESS写聊天室(六)
2006/10/09 PHP
php 日期和时间的处理-郑阿奇(续)
2011/07/04 PHP
ThinkPHP分页类使用详解
2014/03/05 PHP
高性能PHP框架Symfony2经典入门教程
2014/07/08 PHP
PHP统计目录中文件以及目录中目录大小的方法
2016/01/09 PHP
Ajax+PHP实现的模拟进度条功能示例
2019/02/11 PHP
json-lib出现There is a cycle in the hierarchy解决办法
2010/02/24 Javascript
Ajax同步与异步传输的示例代码
2013/11/21 Javascript
详解Bootstrap各式各样的按钮(推荐)
2016/12/13 Javascript
AngularJS ionic手势事件的使用总结
2017/08/09 Javascript
mpvue写一个CPASS小程序的示例
2018/09/04 Javascript
jQuery实现适用于移动端的跑马灯抽奖特效示例
2019/01/18 jQuery
Jquery属性的获取/设置及样式添加/删除操作技巧分析
2019/12/23 jQuery
理解Proxy及使用Proxy实现vue数据双向绑定操作
2020/07/18 Javascript
python和shell变量互相传递的几种方法
2013/11/20 Python
Python的print用法示例
2014/02/11 Python
2款Python内存检测工具介绍和使用方法
2014/06/01 Python
Python编程实现两个文件夹里文件的对比功能示例【包含内容的对比】
2017/06/20 Python
如何用python写一个简单的词法分析器
2018/12/18 Python
Python学习笔记之自定义函数用法详解
2019/06/08 Python
浅析python标准库中的glob
2020/03/13 Python
PYcharm 激活方法(推荐)
2020/03/23 Python
HTML5中新标签和常用标签详解
2014/03/07 HTML / CSS
为有想象力的人提供的生活方式商店:Firebox
2018/06/04 全球购物
微软马来西亚官方网站:Microsoft马来西亚
2019/11/22 全球购物
无故旷工检讨书
2014/01/26 职场文书
保密协议书范本
2014/04/22 职场文书
2014世界杯球队球队口号
2014/06/05 职场文书
四查四看自我剖析材料
2014/09/19 职场文书
党员群众路线剖析材料
2014/10/08 职场文书
党员剖析材料范文
2014/12/18 职场文书
青年文明号汇报材料
2014/12/23 职场文书
学困生转化工作总结
2015/08/13 职场文书
2016先进工作者事迹材料
2016/02/25 职场文书
如何用JavaScipt测网速
2021/05/09 Javascript
pycharm无法安装cv2模块问题
2022/05/20 Python