引用

2018-11-06 python插件式框架开发

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

python 优雅地实现插件架构

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

一. @classmethod + @function装饰器

1.1 项目结构

├─ project

├─ run.py

├─ app

├─ __init__.py

├─ main.py

├─ platform.py

├─ plugins

├─ __init__.py

├─ plugin1.py

├─ plugin2.py

1.2 项目代码

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,不需要在别的任何地方显式地导入插件:from .plugins import * 或 from .plugins import plugin1

若想添加插件 plugin3.py,可将其复制到 plugins 目录下,然后修改 app/plugins/__init__.py 文件为 __all__ = ['plugin1', 'plugin2', 'plugin3']

二. __import__()

import module相当于__import__("module")

from module import func相当于__import__("module", fromlist=["func"])

import package.module相当于__import__("package.module", fromlist=["module"])

2.1 项目结构

|---main.py

\---plugins

plugin1.py

plugin2.py

__init__.py

2.2 项目代码

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

python插件化设计_python - 插件化编程相关推荐

  1. CAD插件-幕墙设计常用插件sama整理

    CAD插件-幕墙设计常用插件sama整理 SWF画弧形焊缝.LSP 标注多段线-(边长A1.对角线A2.角度A3)LSP 尺寸整理(修正)LSP 对齐afLSP 多段线顶点布块-(xxp)LSP 计算 ...

  2. python程序设计教学设计_Python教案 - 教学设计.doc

    时间:课题程序设计基础--绪论教学目标1. 了解程序设计语言的发展历史2. 理解Python语言的特点及其重要性3. 掌握Python语言Hello程序的编写方法4. 掌握Python语言开发的运行环 ...

  3. python插件化设计_Python打造出适合自己的定制化EclipseIDE

    Eclipse是一套强大的框架,其能够通过内置插件机制实现多种扩展方式.然而要想添加一小点额外功能,大家都不可避免地需要面临新插件的编写与部署工作,这显然有点令人头痛.现在在EASE的帮助下,我们能够 ...

  4. python插件使用教程_Python插件机制实现详解

    插件机制是代码/功能反向依赖注入到主体程序的一种方法,编译型语言通过动态加载动态库实现插件.对于Python这样的脚本语言,实现插件机制更简单. 机制 Python的__import__方法可以动态地 ...

  5. python加载机制_Python插件机制实现详解

    插件机制是代码/功能反向依赖注入到主体程序的一种方法,编译型语言通过动态加载动态库实现插件.对于Python这样的脚本语言,实现插件机制更简单. 机制 Python的__import__方法可以动态地 ...

  6. python计算器gui设计_python GUI模拟实现计算器

    python编写计算器,供大家参考,具体内容如下 (1)计算器界面如下: (2)基本满足了计算器的所有需求,使用时不可键盘输入,只能鼠标点击左键才可执行.初始时显示0.0,每次输入的内容存于D:\nu ...

  7. python用电度数设计_Python时间序列预测实战(电力负荷预测)

    这是我之前工作做的一个项目 import os import pandas as pd import numpy path = "E:/工作/负荷预测/历史负荷数据-每天" #文件 ...

  8. python语言特点设计_python语言有什么特点

    详细内容 python语言有什么特点? python语言特点: 1.软件质量(特色) 在很大程度上,python更注重可读性.一致性和软件质量,python的设计致力于可读性,带来了比其他语言更优秀的 ...

  9. python 科学计算设计_Python科学计算——Data Structures

    为什么选择Python作为科学计算语言? 有关于Matlab和Python哪个更适合作为科学计算语言的争论已久,之所以选择Python作为首选的科学计算语言,不仅仅是因为它免费,开源,有很多优秀的库和 ...

最新文章

  1. 送你38个常用的Python库,数值计算、可视化、机器学习等8大领域都有了
  2. 2019计算机应用设计大赛,2019年郑州大学软件与应用科技学院计算机设计大赛成功举办...
  3. 笔记-信息化与系统集成技术-人工智能的特点
  4. 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器(及Windows 10无法找到SQL server配置管理器的解决方法)
  5. [2019杭电多校第十场][hdu6701]Make Rounddog Happy
  6. 大白话5分钟带你走进人工智能-第二节概率基础及高斯分布
  7. sqlite3 命令行操作
  8. EasyUI 中自定义组件 icon 图标
  9. 示波器带宽定义与来源
  10. c语言作业ppt模板,c语言演讲模板ppt
  11. 数理统计 -次序统计量、充分统计量
  12. 一页中关村 · 当百度碰见丧尸
  13. Linux perf 1.1、perf_event内核框架
  14. 《C++ Primer 第5版》-13.3交换操作-康奈尔笔记
  15. 浩辰cad2019破解补丁|浩辰cad2019无限试用破解补丁下载(附浩辰cad2019激活工具/无需激活码)
  16. 关于RedisInsight 创建数据库时 connection time out 连接超时的问题
  17. Java实现 蓝桥杯VIP 算法训练 步与血(递推 || DFS)
  18. 自学Vue之路——Vue介绍及基本语法
  19. 数字化时代,全方位解读商业智能BI
  20. 如何简单有效的删除win10英语美式键盘

热门文章

  1. 【JavaScript学习】JavaScript对象创建
  2. dbgrid 获取前台页面参数
  3. mysql Error 1045(28000)
  4. Linux上Svn环境搭建
  5. python 月报_python实践--月报分析之获取jira缺陷数据
  6. python高维数据_t-SNE高维数据可视化(python)
  7. php生成图片水印,PHP生成图片加文字及图案水印办法
  8. ansys 内聚力_内聚力 软件工程
  9. express 项目生成器_用于项目的Express模板生成器(2)| 应用程序结构研究
  10. math.trunc_带有Python示例的math.trunc()方法