首页 > 编程 > Python > 正文

Python 3.7新功能之dataclass装饰器详解

2020-02-22 23:46:47
字体:
来源:转载
供稿:网友

前言

Python 3.7 将于今年夏天发布,Python 3.7 中将会有许多新东西:

各种字符集的改进 对注释的推迟评估 以及对dataclass的支持

最激动人心的新功能之一是 dataclass 装饰器。

什么是 Data Class

大多数 Python 开发人员编写过很多像下面这样的类:

class MyClass: def __init__(self, var_a, var_b): self.var_a = var_a self.var_b = var_b

dataclass 可以为简单的情况自动生成方法,例如,一个__init__接受这些参数并将其分配给自己,之前的小例子可以重写为:

@dataclassclass MyClass: var_a: str var_b: str

那么通过一个例子来看看如何使用吧

星球大战 API

可以使用 requests 从星球大战 API 获取资源:

response = requests.get('https://swapi.co/api/films/1/')dictionary = response.json()

让我们来看看 dictionary (简化过)的结果:

{ 'characters': ['https://swapi.co/api/people/1/',… ], 'created': '2014-12-10T14:23:31.880000Z', 'director': 'George Lucas', 'edited': '2015-04-11T09:46:52.774897Z', 'episode_id': 4, 'opening_crawl': 'It is a period of civil war./r/n … ', 'planets': ['https://swapi.co/api/planets/2/', … ], 'producer': 'Gary Kurtz, Rick McCallum', 'release_date': '1977-05-25', 'species': ['https://swapi.co/api/species/5/',…], 'starships': ['https://swapi.co/api/starships/2/',…], 'title': 'A New Hope', 'url': 'https://swapi.co/api/films/1/', 'vehicles': ['https://swapi.co/api/vehicles/4/',…]

封装 API

为了正确地封装一个 API,我们应该创建一个用户可以在其应用程序中使用的对象,因此,在Python 3.6 中定义一个对象来包含requests对 /films/endpoint的响应:

class StarWarsMovie: def __init__(self,   title: str,   episode_id: int,   opening_crawl: str,   director: str,   producer: str,   release_date: datetime,   characters: List[str],   planets: List[str],   starships: List[str],   vehicles: List[str],   species: List[str],   created: datetime,   edited: datetime,   url: str   ): self.title = title self.episode_id = episode_id self.opening_crawl= opening_crawl self.director = director self.producer = producer self.release_date = release_date self.characters = characters self.planets = planets self.starships = starships self.vehicles = vehicles self.species = species self.created = created self.edited = edited self.url = url if type(self.release_date) is str:  self.release_date = dateutil.parser.parse(self.release_date) if type(self.created) is str:  self.created = dateutil.parser.parse(self.created) if type(self.edited) is str:  self.edited = dateutil.parser.parse(self.edited)

仔细的读者可能已经注意到这里有一些重复的代码。

这是使用 dataclass 装饰器的经典案例,我们需要创建一个主要用来保存数据的类,只需一点验证,所以让我们来看看我们需要修改什么。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表