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实现将不规范的英文名字首字母大写
Nov 15 Python
python利用正则表达式提取字符串
Dec 08 Python
使用Django Form解决表单数据无法动态刷新的两种方法
Jul 14 Python
python thrift搭建服务端和客户端测试程序
Jan 17 Python
Python读取properties配置文件操作示例
Mar 29 Python
对python产生随机的二维数组实例详解
Dec 13 Python
Python使用lambda表达式对字典排序操作示例
Jul 25 Python
Django接收自定义http header过程详解
Aug 23 Python
Python简易计算器制作方法代码详解
Oct 31 Python
使用python去除图片白色像素的实例
Dec 12 Python
Python 实现使用空值进行赋值 None
Mar 12 Python
keras得到每层的系数方式
Jun 15 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
smtp邮件发送一例
2006/10/09 PHP
PHP编程中尝试程序并发的几种方式总结
2016/03/21 PHP
PHP函数引用返回的实例详解
2016/09/11 PHP
Javascript中的相等与不等运算
2010/04/25 Javascript
jQuery 1.5 源码解读 面向中高阶JSER
2011/04/05 Javascript
jQuery 获取/设置/删除DOM元素的属性以a元素为例
2014/05/23 Javascript
json中换行符的处理方法示例介绍
2014/06/10 Javascript
删除Javascript Object中间的key
2014/11/18 Javascript
js实现时间显示几天前、几小时前或者几分钟前的方法集锦
2015/05/29 Javascript
谈谈JavaScript自定义回调函数
2015/10/18 Javascript
实例讲解JavaScript的Backbone.js框架中的View视图
2016/05/05 Javascript
Javascript对象字面量的理解
2016/06/22 Javascript
基于jQuery实现Ajax验证用户名是否可用实例
2018/03/25 jQuery
javascript关于“时间”的一次探索
2019/07/24 Javascript
通过实例解析JavaScript for in及for of区别
2020/06/15 Javascript
[14:36]2014 DOTA2国际邀请赛中国区预选赛5.21 Orenda VS NE
2014/05/22 DOTA
Python生成验证码实例
2014/08/21 Python
视觉直观感受若干常用排序算法
2017/04/13 Python
python 创建一个空dataframe 然后添加行数据的实例
2018/06/07 Python
解决pandas中读取中文名称的csv文件报错的问题
2018/07/04 Python
Django csrf 验证问题的实现
2018/10/09 Python
通过实例解析python描述符原理作用
2020/01/22 Python
VSCode基础使用与VSCode调试python程序入门的图文教程
2020/03/30 Python
django执行数据库查询之后实现返回的结果集转json
2020/03/31 Python
python中return不返回值的问题解析
2020/07/22 Python
Django修改app名称和数据表迁移方案实现
2020/09/17 Python
Django contrib auth authenticate函数源码解析
2020/11/12 Python
使用CSS3编写灰阶滤镜来制作黑白照片效果的方法
2016/05/09 HTML / CSS
手机配件第一品牌:ZAGG
2017/05/28 全球购物
Bogner美国官网:滑雪服中的”Dior”
2018/01/30 全球购物
eBay美国官网:eBay.com
2020/10/24 全球购物
幼儿园大班开学教师寄语
2014/04/03 职场文书
供用电专业求职信
2014/07/07 职场文书
幼儿园见习总结
2015/06/23 职场文书
Windows Server 2019 安装DHCP服务及相关配置
2022/04/28 Servers
Linux在两个服务器直接传文件的操作方法
2022/08/05 Servers