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 相关文章推荐
Python3基础之条件与循环控制实例解析
Aug 13 Python
python实现上传样本到virustotal并查询扫描信息的方法
Oct 05 Python
Python 绘图和可视化详细介绍
Feb 11 Python
Python编程之字符串模板(Template)用法实例分析
Jul 22 Python
浅析Python中的赋值和深浅拷贝
Aug 15 Python
Python设计模式之观察者模式简单示例
Jan 10 Python
Python基于hashlib模块的文件MD5一致性加密验证示例
Feb 10 Python
新手入门Python编程的8个实用建议
Jul 12 Python
TensorFlow 多元函数的极值实例
Feb 10 Python
解决Django no such table: django_session的问题
Apr 07 Python
python按顺序重命名文件并分类转移到各个文件夹中的实现代码
Jul 21 Python
matplotlib基础绘图命令之imshow的使用
Aug 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
PHP 采集获取指定网址的内容
2010/01/05 PHP
ThinkPHP开发框架函数详解:C方法
2015/08/14 PHP
js 居中漂浮广告
2010/03/21 Javascript
JQuery扩展插件Validate—6 radio、checkbox、select的验证
2011/09/05 Javascript
JavaScript中判断整数的多种方法总结
2014/11/08 Javascript
ECMAScript 6即将带给我们新的数组操作方法前瞻
2015/01/06 Javascript
js数组去重的方法汇总
2015/07/29 Javascript
JSON与XML的区别对比及案例应用
2016/11/11 Javascript
在Vue组件上动态添加和删除属性方法
2018/02/23 Javascript
JavaScript同源策略和跨域访问实例详解
2018/04/03 Javascript
vue短信验证性能优化如何写入localstorage中
2018/04/25 Javascript
Vue SSR 组件加载问题
2018/05/02 Javascript
ionic grid(栅格)九宫格制作详解
2018/06/30 Javascript
JavaScript原型对象、构造函数和实例对象功能与用法详解
2018/08/04 Javascript
video.js 一个页面同时播放多个视频的实例代码
2018/11/27 Javascript
一文读懂ES7中的javascript修饰器
2019/05/06 Javascript
微信小程序实现页面浮动导航
2020/01/08 Javascript
解决Vue 移动端点击出现300毫秒延迟的问题
2020/07/21 Javascript
Python实现二叉堆
2016/02/03 Python
Python的Flask框架应用程序实现使用QQ账号登录的方法
2016/06/07 Python
Python如何读取MySQL数据库表数据
2017/03/11 Python
python开发利器之ulipad的使用实践
2017/03/16 Python
Python二叉搜索树与双向链表转换算法示例
2019/03/02 Python
解决python3.6用cx_Oracle库连接Oracle的问题
2020/12/07 Python
利用CSS3实现开门效果实例源码
2016/08/22 HTML / CSS
美国在线和移动免费会员制批发零售商:Boxed(移动端的Costco)
2020/01/02 全球购物
大学生关于奋斗的演讲稿
2014/01/09 职场文书
《值日生》教学反思
2014/02/17 职场文书
大学本科生职业生涯规划书范文
2014/09/14 职场文书
离婚协议书范本及离婚须知
2014/10/15 职场文书
2014员工聘用协议书(最新版)
2014/11/24 职场文书
答谢词范文
2015/01/05 职场文书
作息时间调整通知
2015/04/22 职场文书
Redis高级数据类型Hyperloglog、Bitmap的使用
2021/05/24 Redis
Python 如何实现文件自动去重
2021/06/02 Python
canvas 中如何实现物体的框选
2022/08/05 Javascript