Python 中面向接口编程


Posted in Python onMay 20, 2022

前言

接口在软件工程扮演重要角色,随着应用程序的功能不断扩展,代码库的更新和改变也难以管理。在许多情况下,会发现有一些看起来非常相似,但却不相关的类,这可能会导致一些难于维护。在本次分享中,将看到你如何使用 Python 接口来帮助确定。

主要从下面几个方面了解内容:

  • 了解接口的工作原理和创建 Python 接口的注意事项
  • 理解接口在像 Python 这样的动态语言中重要性
  • 实现一个非正式的 Python 接口
  • 使用 abc.ABCMeta 和 @abc.abstractmethod 来实现一个正式的 Python 接口

Python 中的接口与大多数其它语言的处理方式不同,它们的设计复杂性也不同。在本教程结束时,你将对 Python 的数据模型的某些方面有更好的理解,以及 Python 中的接口与 Java、C++ 和 Go 等语言中的接口的比较。

概述 Python 接口

在高层次上,接口充当了设计类的蓝图,在接口中,定义了方法与在类中定义并没有什么不同。不过不同于类,这些方法都是抽象方法。一个抽象的方法是定义接口的简单的方式。在这里定义了方法,并不急于实现这些方法。这是由具体的类来完成的,然后由类来实现接口,为接口的抽象方法赋予具体的意义。

与 Java、Go 和 C++ 这些语言相比,Python 的接口设计方法有些不同。这些语言都提供了一个interface 关键字来定义接口,而在 Python 中,却没有提供这个关键字。Python 在另一个方面与其他语言有明显的区别。python 并不要求实现接口的类来定义接口的所有抽象方法

非正式接口

在某些情况下,可能不需要正式的 Python 接口来严格规范。Python 的动态特性允许实现一个非正式的接口。非正式的 Python 接口是一个定义了可以被重载的方法。

在下面的例子中,你将从一个数据工程师的角度出发,他需要从各种不同的非结构化文件类型中提取文本,比如 PDF 和电子邮件。将创建一个非正式的接口,定义 PdfParserEmlParser具体类中的方法。

class InformalParserInterface:
    def load_data_source(self, path: str, file_name: str) -> str:
        """Load in the file for extracting text."""
        pass
    def extract_text(self, full_file_name: str) -> dict:
        """Extract text from the currently loaded file."""
        pass

在 InformalParserInterface类中定义了两个方法,分别是 .load_data_source()和 .extract_text()。 虽然定义了方法却没有实现。接下来我们创建继承 InformalParserInterface的类将需要实现这两个方法。我们关心接口定义了提取文本一般流程,也可以看做规范,也就是我们首先会加载数据源,然后在数据源上提取文本。

InformalParserInterface看起来就是一个标准 python 的 class。不过因为形似接口所以可以将这个类看做一个接口。

你定义了两个实现InformalParserInterface的类。为了使用接口,首先创建一个具体类来继承于。接口,也就是这个类是接口类的子类,提供了接口抽象方法的具体实现。将创建两个具体类来实现你的接口。第一个是PdfParser,将用来解析 PDF 文件的文本。

class PdfParser(InformalParserInterface):
    """Extract text from a PDF"""
    def load_data_source(self, path: str, file_name: str) -> str:
        """Overrides InformalParserInterface.load_data_source()"""
        pass
    def extract_text(self, full_file_path: str) -> dict:
        """Overrides InformalParserInterface.extract_text()"""
        pass

InformalParserInterface的具体实现现在允许你从PDF文件中提取文本。第二个具体的类是EmlParser,将用来解析电子邮件中的文本。

class EmlParser(InformalParserInterface):
    """Extract text from an email"""
    def load_data_source(self, path: str, file_name: str) -> str:
        """Overrides InformalParserInterface.load_data_source()"""
        pass
    def extract_text_from_email(self, full_file_path: str) -> dict:
        """A method defined only in EmlParser.
        Does not override InformalParserInterface.extract_text()
        """
        pass

InformalParserInterface的具体实现现在允许你从电子邮件文件中提取文本。

到目前为止,定义了 InformalPythonInterface的两个具体实现。然而,请注意,EmlParser未能正确定义.extract_text()。要检查EmlParser是否实现了InformalParserInterface 抽象方法,也就是接口方法,可以参照如下代码。

>>> # Check if both PdfParser and EmlParser implement InformalParserInterface
>>> issubclass(PdfParser, InformalParserInterface)
True
>>> issubclass(EmlParser, InformalParserInterface)
True

到此这篇关于Python 中面向接口编程详情的文章就介绍到这了!


Tags in this post...

Python 相关文章推荐
Python的函数嵌套的使用方法
Jan 24 Python
用 Python 爬了爬自己的微信朋友(实例讲解)
Aug 25 Python
Python中列表list以及list与数组array的相互转换实现方法
Sep 22 Python
Python中一行和多行import模块问题
Apr 01 Python
解决python3爬虫无法显示中文的问题
Apr 12 Python
Python面向对象类继承和组合实例分析
May 28 Python
python实现机器学习之元线性回归
Sep 06 Python
解决python打不开文件(文件不存在)的问题
Feb 18 Python
python二维码操作:对QRCode和MyQR入门详解
Jun 24 Python
基于Python pyecharts实现多种图例代码解析
Aug 10 Python
Python接口自动化测试的实现
Aug 28 Python
Python列表的深复制和浅复制示例详解
Feb 12 Python
人工智能深度学习OpenAI baselines的使用方法
May 20 #Python
baselines示例程序train_cartpole.py的ImportError
May 20 #Python
python通过新建环境安装tfx的问题
May 20 #Python
Python使用BeautifulSoup4修改网页内容
May 20 #Python
python标准库ElementTree处理xml
May 20 #Python
Python中使用tkFileDialog实现文件选择、保存和路径选择
May 20 #Python
Python Flask实现进度条
May 11 #Python
You might like
php生成局部唯一识别码LUID的代码
2012/10/06 PHP
PHP定时任务获取微信access_token的方法
2016/10/10 PHP
PHP中rename()函数的妙用讲解
2019/02/28 PHP
javascript 学习之旅 (3)
2009/02/05 Javascript
js内置对象 学习笔记
2011/08/01 Javascript
基于pthread_create,readlink,getpid等函数的学习与总结
2013/07/17 Javascript
javascript将url中的参数加密解密代码
2014/11/17 Javascript
JavaScript变量声明详解
2014/11/27 Javascript
jQuery实现复选框批量选择与反选的方法
2015/06/17 Javascript
BootStrap iCheck插件全选与获取value值的解决方法
2016/08/24 Javascript
Javascript中的async awai的用法
2017/05/17 Javascript
Vue.js 中的 $watch使用方法
2017/05/25 Javascript
JavaScript+HTML5实现的日期比较功能示例
2017/07/12 Javascript
详解vue-admin和后端(flask)分离结合的例子
2018/02/12 Javascript
浅谈vue加载优化策略
2019/03/19 Javascript
详解基于Vue的支持数据双向绑定的select组件
2019/09/02 Javascript
vue如何使用外部特殊字体的操作
2020/07/30 Javascript
jQuery实现鼠标拖拽登录框移动效果
2020/09/13 jQuery
解决基于 keep-alive 的后台多级路由缓存问题
2020/12/23 Javascript
python通过post提交数据的方法
2015/05/06 Python
Python使用matplotlib绘图无法显示中文问题的解决方法
2018/03/14 Python
python 匹配url中是否存在IP地址的方法
2018/06/04 Python
pycharm下查看python的变量类型和变量内容的方法
2018/06/26 Python
如何在django里上传csv文件并进行入库处理的方法
2019/01/02 Python
python3+PyQt5 自定义窗口部件--使用窗口部件样式表的方法
2019/06/26 Python
python实现拉普拉斯特征图降维示例
2019/11/25 Python
python使用scapy模块实现ping扫描的过程详解
2021/01/21 Python
HTML5的Geolocation地理位置定位API使用教程
2016/05/12 HTML / CSS
环境工程大学生自荐信
2013/10/21 职场文书
行政部主管岗位职责
2013/12/28 职场文书
好的演讲稿开场白
2013/12/30 职场文书
护士在校生自荐信
2014/02/01 职场文书
幼儿园中班教师寄语
2014/04/03 职场文书
企业培训简报范文
2015/07/20 职场文书
关于环保的广播稿
2015/12/17 职场文书
只用Python就可以制作的简单词云
2021/06/07 Python