Python: subscript a module

2019-01-20 16:40发布

I was trying to do something like this:

module.py

def __getitem__(item):
    return str(item) + 'Python'

test.py

import module
print module['Monty']

I expected "MontyPython" to be printed. However, this doesn't work:

TypeError: 'module' object is not subscriptable 

Is it possible to create a subscriptable module in pure Python (i.e. without modifying its source code, monkey-patching, etc.)?

1条回答
不美不萌又怎样
2楼-- · 2019-01-20 17:30
>>> class ModModule(object):
    def __init__(self, globals):
        self.__dict__ = globals
        import sys
        sys.modules[self.__name__] = self
    def __getitem__(self, name):
        return self.__dict__[name]


>>> m = ModModule({'__name__':'Mod', 'a':3})
>>> import Mod
>>> Mod['a']
3

# subclassing the actual type won't work
>>> class ModModule(types.ModuleType):
    def __init__(self, globals):
        self.__dict__ = globals
        import sys
        sys.modules[self.__name__] = self
    def __getitem__(self, name):
        return self.__dict__[name]


>>> m = ModModule({'__name__':'Mod', 'a':3})

Traceback (most recent call last):
  File "<pyshell#114>", line 1, in <module>
    m = ModModule({'__name__':'Mod', 'a':3})
  File "<pyshell#113>", line 3, in __init__
    self.__dict__ = globals
TypeError: readonly attribute

you may use ModModule(globals()) to replace the current module in sys.

查看更多
登录 后发表回答