国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

容易被忽略的Python內(nèi)置類型

瀏覽:17日期:2022-07-12 13:04:02

Python中的內(nèi)置類型是我們開發(fā)中最常見的,很多人都能熟練的使用它們。

然而有一些內(nèi)置類型確實不那么常見的,或者說往往會被我們忽略,所以這次的主題就是帶領(lǐng)大家重新認(rèn)識這些“不同尋常”的內(nèi)置類型。

(注意:本文基于python3,不會包含任何python2相關(guān)內(nèi)容)

frozenset

不可變集合(frozenset)與普通的set一樣,只不過它的元素是不可變的,因此諸如`add`,`remove`,`update`等可以添加/刪除/改變集合內(nèi)元素的方法是不存在的,換句話說一旦frozenset建立后你將不再可能更改集合內(nèi)的元素。其他的方法與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`事實上相當(dāng)?shù)贸R姡阅阋苍S會奇怪我為什么把它列出來。其實原因很簡單,因為大部分人熟悉range的使用,但并不清楚range到底是什么。返回迭代器?返回一個可迭代對象?range本身又是什么呢?

答案揭曉:

>>> range<class ’range’>

是的,range是個class!所以當(dāng)我們使用for i in range(1, 10)這樣的代碼時,實際上我們遍歷了一個range對象,而range也實現(xiàn)了可迭代對象需要的__iter__魔法方法,所以它自身是可迭代對象:

>>> range.__iter__<slot wrapper ’__iter__’ of ’range’ objects>

因此,range既不返回迭代器,也不返回其他可迭代對象,而是返回的自己。

bytearray

`bytearray`一般情況下并不常見,它主要為了可以實現(xiàn)原地修改bytes對象而出現(xiàn),因為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 ``` 而當(dāng)我們把bytes的內(nèi)容復(fù)制給`bytearray`時就可以進(jìn)行原地修改了: ```python >>> array = bytearray(b) >>> array[-1] = 98 >>> array.decode(’utf8’) 測試用例b ``` `bytearray`對象沒有字面常量,因此只能通過構(gòu)造函數(shù)創(chuàng)建,它有著和bytes一樣的方法,只是可變以及多了一些序列對象的特性。如果要創(chuàng)建一個`bytearray`可以有如下的幾種方法: - `bytearray()`返回一個空的`bytearray`對象 - `bytearray(10)`創(chuàng)建一個長度為10且內(nèi)容被0填充的`bytearray` - `bytearray(iterable)`會將可迭代對象的內(nèi)容轉(zhuǎn)換成bytes然后存入對象中 - `bytearray(b’Hi!’)`將已有的二進(jìn)制數(shù)據(jù)復(fù)制進(jìn)對象

另外bytearray還提供了fromhex和hex方便將數(shù)據(jù)以16進(jìn)制的形式輸入輸出:

>>> array.hex()’e6b58be8af95e794a8e4be8b62’>>> bytearray().fromhex(’e6b58be8af95e794a8e4be8b62’).decode(’utf8’)’測試用例b’memoryview

`memoryview`提供了直接訪問對象內(nèi)存的機(jī)制,只要目標(biāo)對象支持[buffer protocol](https://docs.python.org/3/c-api/buffer.html#bufferobjects),例如`bytes`和`bytearray`。memoryview有個稱為“元素”的概念,也就是對象規(guī)定的最小的內(nèi)存單元,比如bytes和bytearray的最小內(nèi)存單元就是一個byte,具體取決于對象的實現(xiàn)。

len(view)通常等于len(view.tolist()),也就是等于view的“元素”數(shù)量。如果view.ndim == 0,那么整個view的內(nèi)存會被視作一個整體,len會返回1,如果view.ndim == 1那么就正常返回“元素”的個數(shù)。view.itemsize會返回單個“元素”的大小。單位是byte。

view.readonly表示當(dāng)前的memoryview是否是只讀的,例如bytes對象的view就是只讀的,view.readonly的值為True。是否只讀取決于被引用的對象是否可變以及對buffer protocol的實現(xiàn)。

對于使用完畢的memoryview應(yīng)該盡快調(diào)用其release()方法釋放資源,而且部分對象在被view引用時會自動進(jìn)行一些限制,比如bytearray會禁止調(diào)整大小,及時釋放view是資源可以解除這些限制。

結(jié)合示例可以更清晰地了解這些特性:

>>> data = bytearray(b’abcefg’)>>> v = memoryview(data)>>> v.readonlyFalse>>> v[0] = ord(b’z’)>>> databytearray(b’zbcefg’)>>> v[1:4] = b’123’>>> databytearray(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’>>> databytearray(b’z1spam’)dict-views

準(zhǔn)確的說,這不是一種類型,而是一種概念。然而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動態(tài)反應(yīng)了key/value的插入和刪除以及修改,因此在某些場景下views對象是相當(dāng)有用的。

The Ellipsis Object (...)

`...`不是一個類型,不過算是一個內(nèi)置對象。它沒什么特殊的含義,僅表示省略,通常被用在type hints中:

>>> ...Ellipsis>>> from typing import Callable>>> func: Callable[..., None] = lambda x,y:print(x*y)

func是一個沒有返回值的函數(shù),參數(shù)列表沒有做任何限制。

你也可以寫成Ellipsis,兩者是等價的,不過顯然是...這種形式更簡單明了。

以上就是這些容易被忽略和遺忘的內(nèi)置類型,如有錯誤和疏漏歡迎指出。

參考:

https://docs.python.org/3/library/stdtypes.html

https://docs.python.org/3/c-api/buffer.html#bufferobjects

以上就是容易被忽略的Python內(nèi)置類型的詳細(xì)內(nèi)容,更多關(guān)于Python內(nèi)置類型的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 欧美一级精品高清在线观看 | 97视频在线观看免费视频 | 免费特黄级夫费生活片 | 色一情 | 美女一级毛片 | 中国嫩模一级毛片 | 亚洲免费片 | 男女免费观看在线爽爽爽视频 | 欧美日韩在线视频 | 国产亚洲精品成人久久网站 | 99精彩视频在线观看 | 日韩欧美视频在线一区二区 | 亚洲精品久久久久午夜三 | xxxxx亚洲 | 美女张开大腿让男人捅 | 中文字幕一区二区三区在线观看 | 精品国产亚洲一区二区在线3d | 性欧美久久 | 午夜香蕉网 | 欧美特黄一级 | 国产亚洲三级 | 国产日产亚洲系列首页 | 三级高清| 男女一级 | 国产一级淫片a免费播放口之 | 亚州一级毛片 | 国产一级视频久久 | 97视频在线观看免费 | 日韩 欧美 中文 亚洲 高清 在线 | a级国产精品片在线观看 | 中文国产成人精品久久一区 | 成人三级精品视频在线观看 | 欧美一级xxx | 亚洲日本高清影院毛片 | 午夜桃色剧场 | 男人的天堂久久香蕉国产 | 久久国产精品免费一区二区三区 | 宅女福利视频在线看免费网站 | 日韩字幕一中文在线综合 | 99爱精品视频 | 欧洲乱码伦视频免费 |