日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > python >内容正文

python

python插件化设计_python - 插件化编程

發(fā)布時(shí)間:2025/3/11 python 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python插件化设计_python - 插件化编程 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

引用

2018-11-06 python插件式框架開發(fā)

https://www.jianshu.com/p/a472f44c7161

python 優(yōu)雅地實(shí)現(xiàn)插件架構(gòu)

https://www.cnblogs.com/hhh5460/p/6681363.html

一. @classmethod + @function裝飾器

1.1 項(xiàng)目結(jié)構(gòu)

├─ project

├─ run.py

├─ app

├─ __init__.py

├─ main.py

├─ platform.py

├─ plugins

├─ __init__.py

├─ plugin1.py

├─ plugin2.py

1.2 項(xiàng)目代碼

project/run.py# -*- coding: UTF-8 -*-

from app.main import test

test()

project/app/__init__.py# -*- coding: UTF-8 -*-

__all__ = ['plugin1', 'plugin2']

project/app/main.py# -*- coding: UTF-8 -*-

from .platform import TextProcessor

def test():

processor = TextProcessor()

print(processor.PLUGINS)

processed = processor.process(text="**foo bar**", plugins=('plugin1', ))

processed = processor.process(text="--foo bar--")

project/app/platform.py# -*- coding: UTF-8 -*-

class TextProcessor(object):

PLUGINS = {}

def process(self, text, plugins=()):

if plugins == ():

print("------Run all registered plugins:")

for plugin_name in self.PLUGINS.keys():

print("--Excute the {} plugin--".format(plugin_name))

res= self.PLUGINS[plugin_name]().process(text)

else:

print("------Run all specified plugins:")

for plugin_name in plugins:

print("--Excute the {} plugin--".format(plugin_name))

res= self.PLUGINS[plugin_name]().process(text)

return res

@classmethod

def plugin_register(cls, plugin_name):

def wrapper(plugin):

print(plugin)

cls.PLUGINS.update({plugin_name:plugin})

return plugin

return wrapper

project/app/plugins/__init__.py# -*- coding: UTF-8 -*-

from .plugins import *

project/app/plugins/plugin1.py# -*- coding: UTF-8 -*-

from ..platform import TextProcessor

@TextProcessor.plugin_register('plugin1')

class CleanMarkdownBolds(object):

def process(self, text):

print("I am plugin1")

return 0

project/app/plugins/plugin2.py# -*- coding: UTF-8 -*-

from ..platform import TextProcessor

@TextProcessor.plugin_register('plugin2')

class CleanMarkdownItalic(object):

def process(self, text):

print("I am plugin2")

return 0

1.3 Readme

在 app 目錄下,除了?app/__init__.py,不需要在別的任何地方顯式地導(dǎo)入插件:from .plugins import *?或?from .plugins import plugin1

若想添加插件 plugin3.py,可將其復(fù)制到 plugins 目錄下,然后修改?app/plugins/__init__.py?文件為?__all__ = ['plugin1', 'plugin2', 'plugin3']

二. __import__()

import module相當(dāng)于__import__("module")

from module import func相當(dāng)于__import__("module", fromlist=["func"])

import package.module相當(dāng)于__import__("package.module", fromlist=["module"])

2.1 項(xiàng)目結(jié)構(gòu)

|---main.py

\---plugins

plugin1.py

plugin2.py

__init__.py

2.2 項(xiàng)目代碼

main.py# -*- coding: UTF-8 -*-

import os

class Platform:

def __init__(self):

self.plugins = []

self.loadPlugins()

def loadPlugins(self):

for filename in os.listdir("plugins"):

if not filename.endswith(".py") or filename.startswith("_"):

continue

self.runPlugin(filename)

def runPlugin(self, filename):

pluginName = os.path.splitext(filename)[0]

print("------Import {}------".format(pluginName))

plugin = __import__("plugins." + pluginName, fromlist=[pluginName])

clazz = plugin.getPluginClass()

o = clazz()

o.setPlatform(self)

print("Run {}:".format(pluginName))

o.start()

self.plugins.append(o)

def sayHello(self, from_):

print("hello from {}.".format(from_))

def sayGoodbye(self, from_):

print("goodbye from {}.".format(from_))

def shutdown(self):

print("------Shutdown ------")

for o in self.plugins:

o.stop()

o.setPlatform(None)

self.plugins = []

if __name__ == "__main__":

platform = Platform()

platform.shutdown()

/plugins/plugin1.py# -*- coding: UTF-8 -*-

class Plugin1:

def setPlatform(self, platform):

self.platform = platform

def start(self):

self.platform.sayHello("plugin1")

def stop(self):

self.platform.sayGoodbye("plugin1")

def getPluginClass():

return Plugin1

/plugins/plugin2.py# -*- coding: UTF-8 -*-

class Plugin2:

def setPlatform(self, platform):

self.platform = platform

def start(self):

self.platform.sayHello("plugin2")

def stop(self):

self.platform.sayGoodbye("plugin2")

def getPluginClass():

return Plugin2

總結(jié)

以上是生活随笔為你收集整理的python插件化设计_python - 插件化编程的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。