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多线程ctrl+c退出问题解决方案
Oct 23 Python
Python pass详细介绍及实例代码
Nov 24 Python
Python编程实现的图片识别功能示例
Aug 03 Python
Python设计模式之代理模式简单示例
Jan 09 Python
Python3多线程操作简单示例
May 22 Python
Django处理文件上传File Uploads的实例
May 28 Python
Python3.4学习笔记之常用操作符,条件分支和循环用法示例
Mar 01 Python
详解Python字符串切片
May 20 Python
Python帮你识破双11的套路
Nov 11 Python
Python3的unicode编码转换成中文的问题及解决方案
Dec 10 Python
Kmeans均值聚类算法原理以及Python如何实现
Sep 26 Python
Python结合百度语音识别实现实时翻译软件的实现
Jan 18 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 冒泡排序 交换排序法
2011/05/10 PHP
如何使用GDB调试PHP程序
2015/12/08 PHP
php获取微信共享收货地址的方法
2017/12/21 PHP
jQuery jqgrid 对含特殊字符json 数据的 Java 处理方法
2011/01/01 Javascript
在每个匹配元素的外部插入新元素的方法
2013/12/20 Javascript
一个简单的动态加载js和css的jquery代码
2014/09/01 Javascript
Javascript优化技巧之短路表达式详细介绍
2015/03/27 Javascript
ECMAScript6函数剩余参数(Rest Parameters)
2015/06/12 Javascript
使用Object.defineProperty实现简单的js双向绑定
2016/04/15 Javascript
Bootstrap布局方式详解
2016/05/27 Javascript
老生常谈js-react组件生命周期
2017/05/02 Javascript
mac上node.js环境的安装测试
2017/07/03 Javascript
深入理解Vue 的条件渲染和列表渲染
2017/09/01 Javascript
Vue中使用vux配置代码详解
2018/09/16 Javascript
可拖拽组件slider.js使用方法详解
2020/12/04 Javascript
Python中for循环控制语句用法实例
2015/06/02 Python
python中文分词教程之前向最大正向匹配算法详解
2017/11/02 Python
教你用 Python 实现微信跳一跳(Mac+iOS版)
2018/01/04 Python
Jupyter中直接显示Matplotlib的图形方法
2018/05/24 Python
Python爬虫包BeautifulSoup实例(三)
2018/06/17 Python
Python自定义装饰器原理与用法实例分析
2018/07/16 Python
Python 转换RGB颜色值的示例代码
2019/10/13 Python
python的json中方法及jsonpath模块用法分析
2019/12/06 Python
使用python检查yaml配置文件是否符合要求
2020/04/09 Python
解决Tensorflow2.0 tf.keras.Model.load_weights() 报错处理问题
2020/06/12 Python
Python使用文件操作实现一个XX信息管理系统的示例
2020/07/02 Python
Python extract及contains方法代码实例
2020/09/11 Python
HTML5给汉字加拼音收起展开组件的实现代码
2020/04/08 HTML / CSS
酷瑞网络科技面试题
2012/03/30 面试题
酒吧总经理岗位职责
2013/12/10 职场文书
公司行政经理岗位职责
2013/12/24 职场文书
银行内勤岗位职责
2014/04/09 职场文书
孝敬父母的活动方案
2014/08/31 职场文书
《鸡兔同笼》教学反思
2016/02/19 职场文书
八年级作文之友谊
2019/12/02 职场文书
netty 实现tomcat的示例代码
2022/06/05 Servers