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标准库内置函数complex介绍
Nov 25 Python
Django中使用group_by的方法
May 26 Python
使用PyInstaller将Python程序文件转换为可执行程序文件
Jul 08 Python
Python多线程经典问题之乘客做公交车算法实例
Mar 22 Python
Python中使用Counter进行字典创建以及key数量统计的方法
Jul 06 Python
Python 生成一个从0到n个数字的列表4种方法小结
Nov 28 Python
Python内建序列通用操作6种实现方法
Mar 26 Python
python数据库编程 Mysql实现通讯录
Mar 27 Python
python3通过udp实现组播数据的发送和接收操作
May 05 Python
深入理解Python 多线程
Jun 16 Python
django models里数据表插入数据id自增操作
Jul 15 Python
OpenCV读取与写入图片的实现
Oct 13 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
帅气的琦玉老师
2020/03/02 日漫
星际争霸兵种名称对照表
2020/03/04 星际争霸
smarty的保留变量问题
2008/10/23 PHP
ThinkPHP中实例Model方法的区别说明
2010/08/21 PHP
php实现mysql封装类示例
2014/05/07 PHP
PHP+ajaxfileupload+jcrop插件完美实现头像上传剪裁
2014/06/09 PHP
php实现的短网址算法分享
2014/06/20 PHP
php用户密码加密算法分析【Discuz加密算法】
2016/10/12 PHP
PHP数字金额转换成中文大写显示
2019/01/05 PHP
多个js与css文件的合并方法详细说明
2012/12/26 Javascript
js弹出窗口之弹出层的小例子
2013/06/17 Javascript
js 判断控件获得焦点的示例代码
2014/03/04 Javascript
jquery中map函数与each函数的区别实例介绍
2014/06/23 Javascript
jquery用offset()方法获得元素的xy坐标
2014/09/06 Javascript
jQuery匹配文档链接并添加class的方法
2015/06/26 Javascript
基于jQuery实现的无刷新表格分页实例
2016/02/17 Javascript
JavaScript计时器用法分析【setTimeout和clearTimeout】
2017/01/18 Javascript
js中开关变量使用实例
2017/02/24 Javascript
JS如何获取地址栏的参数实例讲解
2018/10/06 Javascript
Vue export import 导入导出的多种方式与区别介绍
2020/02/12 Javascript
更改Python命令行交互提示符的方法
2015/01/14 Python
python实现按任意键继续执行程序
2016/12/30 Python
Python基于滑动平均思想实现缺失数据填充的方法
2019/02/21 Python
用css3写出气球样式的示例代码
2017/09/11 HTML / CSS
移动HTML5前端框架—MUI的使用
2017/12/18 HTML / CSS
加拿大休闲和工业服装和鞋类零售商:L’Équipeur
2018/01/12 全球购物
医学专业五年以上个人求职信
2013/12/03 职场文书
优秀员工自荐书
2013/12/19 职场文书
证券期货行业个人的自我评价
2013/12/26 职场文书
企业2014年度工作总结
2014/12/10 职场文书
商务宴请邀请函范文
2015/02/02 职场文书
考研经验交流会策划书
2015/11/02 职场文书
2016年父亲节寄语
2015/12/04 职场文书
护士业务学习心得体会
2016/01/25 职场文书
《中国古代诗歌散文欣赏》高中语文教材
2019/08/20 职场文书
如何利用React实现图片识别App
2022/02/18 Javascript