collections.abc
--- コレクションの抽象基底クラス¶
バージョン 3.3 で追加:以前はこのモジュールはcollections
モジュールの一部でした。
ソースコード:Lib/_collections_abc.py
This module providesabstract base classes thatcan be used to test whether a class provides a particular interface; forexample, whether it ishashable or whether it is a mapping.
issubclass()
やisinstance()
を使ったインターフェースに対するテストは、以下の3つのいずれかの方法で動作します。
1) 新しく定義したクラスは抽象基底クラスのいずれかを直接継承することができます。その場合クラスは必要な抽象メソッドを提供しなければなりません。残りのミックスインメソッドは継承により引き継がれますが、必要ならオーバーライドすることができます。その他のメソッドは必要に応じて追加することができます:
classC(Sequence):# Direct inheritancedef__init__(self):...# Extra method not required by the ABCdef__getitem__(self,index):...# Required abstract methoddef__len__(self):...# Required abstract methoddefcount(self,value):...# Optionally override a mixin method
>>>issubclass(C,Sequence)True>>>isinstance(C(),Sequence)True
2) 既存のクラスや組み込みのクラスを "仮想派生クラス" として ABC に登録することができます。これらのクラスは、全ての抽象メソッドとミックスインメソッドを含む完全な API を定義する必要があります。これにより、そのクラスが完全なインターフェースをサポートしているかどうかを、ユーザーがissubclass()
やisinstance()
で判断できるようになります。このルールの例外は、残りの API から自動的に推測ができるようなメソッドです:
classD:# No inheritancedef__init__(self):...# Extra method not required by the ABCdef__getitem__(self,index):...# Abstract methoddef__len__(self):...# Abstract methoddefcount(self,value):...# Mixin methoddefindex(self,value):...# Mixin methodSequence.register(D)# Register instead of inherit
>>>issubclass(D,Sequence)True>>>isinstance(D(),Sequence)True
この例では、クラスD
は__contains__
,__iter__
,__reversed__
を定義する必要がありません。なぜならin 演算子, the反復 ロジック, およびreversed()
関数は自動的に__getitem__
と__len__
を使うようにフォールバックするからです。
3) いくつかの単純なインターフェースは、必要なメソッドの存在だけで (それらのメソッドがNone
に設定されていなければ) 直接認識されます:
classE:def__iter__(self):...def__next__(next):...
>>>issubclass(E,Iterable)True>>>isinstance(E(),Iterable)True
複雑なインターフェースは、単に特定のメソッドが存在すること以上の定義を持つため、3番目のテクニックをサポートしていません。それらのインターフェースはメソッドの意味やメソッド間の関係まで指定するので、特定のメソッド名の存在からだけではインターフェースの推測ができません。たとえば、あるクラスが__getitem__
,__len__
, および__iter__
を提供するというだけでは、Sequence
とMapping
を区別するには不十分です。
バージョン 3.9 で追加:これらの抽象クラスは[]
をサポートするようになりました。ジェネリックエイリアス型 およびPEP 585 を参照してください。
コレクション抽象基底クラス¶
collections モジュールは以下のABC (抽象基底クラス) を提供します:
ABC | 継承しているクラス | 抽象メソッド | mixin メソッド |
---|---|---|---|
| |||
| |||
| |||
|
| ||
| |||
|
| ||
| |||
| |||
| |||
|
| ||
|
| ||
|
| ||
|
| ||
|
| ||
|
| ||
|
| ||
| |||
| |||
| |||
| |||
| |||
|
| ||
| |||
|
| ||
|
|
脚注
- 1(1,2,3,4,5,6,7,8,9,10,11,12,13,14)
これらの抽象基底クラスは
object.__subclasshook__()
をオーバーライドして、必要なメソッドが存在し、かつNone
に指定されていないことを確かめることによってインターフェースをテストすることをサポートします。このテストは単純なインターフェースに対してのみ有効に働きます。より複雑なインターフェースは基底クラスへの登録や直接派生することが必要になります。- 2
isinstance(obj,Iterable)
によるチェックはIterable
として登録されたクラスや__iter__()
メソッドを持つクラスを検出しますが、__getitem__()
メソッドにより反復処理を行うクラスは検出しません。オブジェクトがイテラブル (iterable) かどうかを確認する唯一の信頼できる方法はiter(obj)
を呼び出すことです。
コレクションの抽象基底クラス -- 詳細な説明¶
- class
collections.abc.
Container
¶ __contains__()
メソッドを提供するクラスの ABC です。
- class
collections.abc.
Hashable
¶ __hash__()
メソッドを提供するクラスの ABC です。
- class
collections.abc.
Sized
¶ __len__()
メソッドを提供するクラスの ABC です。
- class
collections.abc.
Callable
¶ __call__()
メソッドを提供するクラスの ABC です。
- class
collections.abc.
Iterable
¶ __iter__()
メソッドを提供するクラスの ABC です。メソッド
isinstance(obj,Iterable)
で使用すると、Iterable
や__iter__()
メソッドを持っているクラスを検出できます。しかし、__getitem__()
メソッドで反復するクラスは検出しません。オブジェクトがiterable であるかどうかを判別するにあたって、信頼できる唯一の方法はiter(obj)
を呼び出す方法です。
- class
collections.abc.
Collection
¶ サイズ付きのイテラブルなコンテナクラスの ABC です。
バージョン 3.6 で追加.
- class
collections.abc.
Iterator
¶ __iter__()
メソッドと__next__()
メソッドを提供するクラスの ABC です。iterator の定義も参照してください。
- class
collections.abc.
Reversible
¶ __reversed__()
メソッドを提供するイテラブルクラスの ABC です。バージョン 3.6 で追加.
- class
collections.abc.
Generator
¶ PEP 342 で定義された、イテレータを
send()
,throw()
,close()
の各メソッドに拡張するプロトコルを実装する、ジェネレータクラスの ABC です。generator の定義も参照してください。バージョン 3.5 で追加.
- class
collections.abc.
Sequence
¶ - class
collections.abc.
MutableSequence
¶ - class
collections.abc.
ByteString
¶ 読み出し専用のシーケンス およびミュータブルなシーケンス の ABC です。
実装における注意:
__iter__()
,__reversed__()
,index()
など、一部の mixin メソッドは、下層の__getitem__()
メソッドを繰り返し呼び出します。その結果、__getitem__()
が定数のアクセス速度で実装されている場合、mixin メソッドは線形のパフォーマンスとなります。下層のメソッドが線形 (リンクされたリストの場合など) の場合、mixin は 2 乗のパフォーマンスとなるため、多くの場合上書きする必要があるでしょう。バージョン 3.5 で変更:index() メソッドはstop とstart 引数をサポートしました。
- class
collections.abc.
MappingView
¶ - class
collections.abc.
ItemsView
¶ - class
collections.abc.
KeysView
¶ - class
collections.abc.
ValuesView
¶ マッピング、要素、キー、値のビュー の ABC です。
- class
collections.abc.
Awaitable
¶ await
で使用できるawaitable オブジェクトの ABC です。カスタムの実装は、__await__()
メソッドを提供しなければなりません。Coroutine
ABC のCoroutine オブジェクトとインスタンスは、すべてこの ABC のインスタンスです。注釈
CPython では、ジェネレータベースのコルーチン (
types.coroutine()
またはasyncio.coroutine()
でデコレートされたジェネレータ) は、__await__()
メソッドを持ちませんが、待機可能 (awaitables) です。これらに対してisinstance(gencoro,Awaitable)
を使用すると、False
が返されます。これらを検出するには、inspect.isawaitable()
を使用します。バージョン 3.5 で追加.
- class
collections.abc.
Coroutine
¶ コルーチンと互換性のあるクラスの ABC です。これらは、コルーチンオブジェクト で定義された
send()
,throw()
,close()
のメソッドを実装します。カスタムの実装は、__await__()
も実装しなければなりません。Coroutine
のすべてのインスタンスは、Awaitable
のインスタンスでもあります。coroutine の定義も参照してください。注釈
CPython では、ジェネレータベースのコルーチン (
types.coroutine()
またはasyncio.coroutine()
でデコレートされたジェネレータ) は、__await__()
メソッドを持ちませんが、待機可能 (awaitables) です。これらに対してisinstance(gencoro,Coroutine)
を使用すると、False
が返されます。これらを検出するには、inspect.isawaitable()
を使用します。バージョン 3.5 で追加.
- class
collections.abc.
AsyncIterable
¶ __aiter__
メソッドを提供するクラスの ABC です。asynchronous iterable の定義も参照してください。バージョン 3.5 で追加.
- class
collections.abc.
AsyncIterator
¶ __aiter__
および__anext__
メソッドを提供するクラスの ABC です。asynchronous iterator の定義も参照してください。バージョン 3.5 で追加.
例とレシピ¶
抽象基底クラスは、クラスやインスタンスが特定の機能を提供しているかどうかを調べることを可能にします。例えば:
size=Noneifisinstance(myvar,collections.abc.Sized):size=len(myvar)
幾つかの ABC はコンテナ型 API を提供するクラスを開発するのを助ける mixin 型としても使えます。例えば、Set
API を提供するクラスを作る場合、3つの基本になる抽象メソッド__contains__()
,__iter__()
,__len__()
だけが必要です。ABC が残りの__and__()
やisdisjoint()
といったメソッドを提供します:
classListBasedSet(collections.abc.Set):''' Alternate set implementation favoring space over speed and not requiring the set elements to be hashable. '''def__init__(self,iterable):self.elements=lst=[]forvalueiniterable:ifvaluenotinlst:lst.append(value)def__iter__(self):returniter(self.elements)def__contains__(self,value):returnvalueinself.elementsdef__len__(self):returnlen(self.elements)s1=ListBasedSet('abcdef')s2=ListBasedSet('defghi')overlap=s1&s2# The __and__() method is supported automatically
Set
とMutableSet
を mixin 型として利用するときの注意点:
幾つかの set の操作は新しい set を作るので、デフォルトの mixin メソッドは iterable から新しいインスタンスを作成する方法を必要とします。クラスのコンストラクタは
ClassName(iterable)
の形のシグネチャを持つと仮定されます。内部の_from_iterable()
というクラスメソッドがcls(iterable)
を呼び出して新しい set を作る部分でこの仮定が使われています。コンストラクタのシグネチャが異なるクラスでSet
を使う場合は、 iterable 引数から新しいインスタンスを生成できるクラスメソッドあるいは仕様に沿ったメソッドで_from_iterable()
をオーバーライドする必要があります。(たぶん意味はそのままに速度を向上する目的で)比較をオーバーライドする場合、
__le__()
と__ge__()
だけを再定義すれば、その他の演算は自動的に追随します。The
Set
mixin provides a_hash()
method to compute a hash valuefor the set; however,__hash__()
is not defined because not all setsarehashable or immutable. To add set hashability using mixins,inherit from bothSet()
andHashable()
, then define__hash__=Set._hash
.
参考
MutableSet
を使った例としてOrderedSet recipe。