开发者

Dynamic module import of class list from module given its full path

开发者 https://www.devze.com 2023-02-14 10:35 出处:网络
First, it seems proper to me to state that I\'ve read over the following questions: Python imports by folder module

First, it seems proper to me to state that I've read over the following questions:

  • Python imports by folder module
  • Dynamic module import in Python

And, I don't feel like they address my use case. That said, here's my question:

How can I dynamically import from a configuration file like this:

[imports]
/var/imports/foo.py = baz monkey
/var/imports/bar.py = ape

So that I can call the known objects via RESTful interface like this.

# http://localhost/data?operation=get&class=baz&id=1
def handler(object):
  def handle(self):
    cls = instantiate(request.args["class"])
    meth = request.args["operation"]
    return getatt开发者_如何学Pythonr(cls,meth,request.args)

And it could respond with the result of get() on an instance of that class.


Look at the 2nd link again. It already mentions imp.load_source:

import imp

# some sort of shared dict for everything imported
loaded = {}

def load(path, from_list):
    # load the path
    module = imp.load_source( "dummy", path)
    for name in from_list:
        # add the names
        loaded[name] = getattr(module, name)

#lets say you have this:
data = "/var/imports/foo.py", ["baz"]
load(*data)
print loaded['baz'] # whatever foo.baz was

Now you can do something like this:

def instantiate( clsname ):
    obj = loaded[clsname]
    return obj()

I hope this gets you started.


Here's a rough sketch of a class registry you could use like this:

class ClassRegistry(object):

    def __init__(self):
        self.classes = {}

    def add_file_classes(self, fname, class_list):
        globals = {}
        exec open(fname) in globals
        for class_name in class_list:
            self.classes[class_name] = getattr(globals, class_name)

    def get_class(self, class_name):
        return self.classes[class_name]

Read your config file and invoke add_file_classes like this:

reg = ClassRegistry()
reg.add_file_classes("/var/imports/foo.py", ["baz", "monkey"])
reg.add_file_classes("/var/imports/bar.py", ["ape"])

then later:

cls = reg.get_class("baz")

Note that we aren't actually importing the files, simply executing them and collecting their results.

0

精彩评论

暂无评论...
验证码 换一张
取 消