getattr
を使用してモジュールにクラスのような動作を動的に実装するシナリオによっては、模倣することが望ましい場合があります。クラスに対する __getattr__ の動作 (モジュール全体に対するもの)。これにより、クラス インスタンスの動的な作成と、モジュールの属性検索に基づいたメソッドの呼び出しが可能になります。
ただし、モジュールで __getattr__ メソッドを直接定義しようとすると、次の 2 つの障害に直面します:
ラッパーベースのソリューション
1 つのアプローチは、モジュールの周囲にラッパーを作成することです。 Sys.modules はさまざまなオブジェクト タイプに対応しているため、モジュールをクラス内にラップして sys.modules[__name__] に割り当てることができます。これにより、モジュール自体を変更せずに動的な動作が可能になります。ただし、この手法はモジュール レベルのアクセスにのみ適用されます。
Guido van Rossum の Hack
Guido van Rossum が提案した別の解決策には、sys 内の実際のモジュールを置き換えることが含まれます。モジュール内で定義されたクラスのインスタンスを持つモジュール。インポート機構がこの最後の置換ステップを実行し、このハッキングを可能にします。次の例は、このアプローチを示しています:
# module foo.py
import sys
class Foo:
def funct1(self, *args):
def funct2(self, *args):
sys.modules[__name__] = Foo()
これで、モジュールで定義された関数には Foo.
Discussions
[ のインスタンスを介してアクセスできます。 &&&]これらの手法を使用すると、sys.modules の割り当て後に他のモジュール要素にアクセスできなくなる可能性があります。モジュールの内容が失われないように、置換クラス内で必要な機能をすべて定義します。__all__ 属性
モジュールインポート * から使用する場合は、これを処理するために置換クラスで __all__ を定義します。 import ステートメントのタイプ。 __all__.から __module__ や __qualname__ などの属性を省略します。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3