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之wxPython应用实例
Sep 28 Python
举例讲解Python面向对象编程中类的继承
Jun 17 Python
Python+selenium实现自动循环扔QQ邮箱漂流瓶
May 29 Python
Python开发的十个小贴士和技巧及长常犯错误
Sep 27 Python
python开发游戏的前期准备
May 05 Python
ipad上运行python的方法步骤
Oct 12 Python
Python序列类型的打包和解包实例
Dec 21 Python
Python使用docx模块实现刷题功能代码
Feb 13 Python
解决Jupyter Notebook开始菜单栏Anaconda下消失的问题
Apr 13 Python
keras得到每层的系数方式
Jun 15 Python
python反爬虫方法的优缺点分析
Nov 25 Python
python自动计算图像数据集的RGB均值
Jun 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 session 错误
2009/05/21 PHP
PHP array 的加法操作代码
2010/07/24 PHP
PHP file_exists问题杂谈
2012/05/07 PHP
php面向对象中的魔术方法中文说明
2014/03/04 PHP
php实现的SESSION类
2014/12/02 PHP
PHP快速生成各种信息提示框的方法
2016/02/03 PHP
PHP中类与对象功能、用法实例解读
2020/03/27 PHP
javascript vvorld 在线加密破解方法
2008/11/13 Javascript
ExtJS扩展 垂直tabLayout实现代码
2009/06/21 Javascript
JavaScript格式化数字的函数代码
2010/11/30 Javascript
javascript修改IMG标签的src问题
2014/03/28 Javascript
一款基jquery超炫的动画导航菜单可响应单击事件
2014/11/02 Javascript
jQuery使用hide方法隐藏元素自身用法实例
2015/03/30 Javascript
JavaScript通过Date-Mask将日期转换成字符串的方法
2015/06/04 Javascript
JS实现自定义简单网页软键盘效果代码
2015/11/05 Javascript
基于jQuery实现收缩展开功能
2016/03/18 Javascript
bootstrap css样式之表单
2017/01/19 Javascript
ES6正则表达式扩展笔记
2017/07/25 Javascript
Vue 进入/离开动画效果
2017/12/26 Javascript
vue将毫秒数转化为正常日期格式的实例
2018/09/16 Javascript
Node.JS在命令行中检查Chrome浏览器是否安装并打开指定网址
2019/05/21 Javascript
在Vue中用canvas实现二维码和图片合成海报的方法
2019/06/10 Javascript
JS函数参数的传递与同名参数实例分析
2020/03/16 Javascript
c++生成dll使用python调用dll的方法
2014/01/20 Python
命令行运行Python脚本时传入参数的三种方式详解
2019/10/11 Python
使用keras时input_shape的维度表示问题说明
2020/06/29 Python
python 爬取腾讯视频评论的实现步骤
2021/02/18 Python
HTML5离线缓存在tomcat下部署可实现图片flash等离线浏览
2012/12/13 HTML / CSS
Jacadi Paris美国官方网站:法国童装品牌
2017/10/15 全球购物
村委会贫困证明
2014/01/14 职场文书
我的梦想演讲稿500字
2014/08/21 职场文书
群众路线教育实践活动调研报告
2014/11/03 职场文书
农村党员干部承诺书
2015/05/04 职场文书
2015年电教工作总结
2015/05/26 职场文书
MySQL中你可能忽略的COLLATION实例详解
2021/05/12 MySQL
Python 多线程处理任务实例
2021/11/07 Python