我有以下类与变量from,to和rate.from是一个关键字.如果我想在下面的init方法中使用它,那么编写它的正确方法是什么?
更多上下文:类需要from显式变量,因为它是由另一个开发人员用不同语言编写的POST端点所需的json的一部分.因此,改变变量名是不可能的.
class ExchangeRates(JsonAware):
def __init__(self, from, to, rate):
self.from = from
self.to = to
self.rate = rate
Run Code Online (Sandbox Code Playgroud)
JsonAware代码:
class PropertyEquality(object):
def __eq__(self, other):
return (isinstance(other, self.__class__) and self.__dict__ == other.__dict__)
def __ne__(self, other):
return not self.__eq__(other)
def __repr__(self):
return '%s(%s)' % (self.__class__.__name__, ', '.join(['%s=%s' % (k, v) for (k, v) in self.__dict__.items()]))
class JsonAware(PropertyEquality):
def json(self):
return json.dumps(self, cls=GenericEncoder)
@classmethod
def from_json(cls, json):
return cls(**json)
Run Code Online (Sandbox Code Playgroud)
GenericEncoder代码:
class GenericEncoder(json.JSONEncoder):
def default(self, obj):
return obj.__dict__
Run Code Online (Sandbox Code Playgroud)
为您的首选名称添加一个下划线:from_ 和 to_
(见PEP 8)
class ExchangeRates(JsonAware):
def __init__(self, from_, to_, rate):
self.from = from_
self.to = to_
self.rate = rate
Run Code Online (Sandbox Code Playgroud)
正如评论中提到的,from是一个 Python 关键字,因此您不能将其用作变量名称或属性名称。因此,您需要使用替代名称,并在读取或写入 JSON 数据时进行转换。
要进行输出转换,您可以提供一个新的编码器json.dumps;您可以通过覆盖该ExchangeRates.json方法来做到这一点。要进行输入转换,请覆盖ExchangeRates.from_json.
这两种情况的策略是相似的:我们创建字典的副本(这样我们就不会改变原始字典),然后创建一个具有所需名称和值的新键,然后删除旧键。
这是一个在 Python 2.6 和 3.6 上测试的快速演示:
import json
class PropertyEquality(object):
def __eq__(self, other):
return (isinstance(other, self.__class__) and self.__dict__ == other.__dict__)
def __ne__(self, other):
return not self.__eq__(other)
def __repr__(self):
return '%s(%s)' % (self.__class__.__name__, ', '.join(['%s=%s' % (k, v) for (k, v) in self.__dict__.items()]))
class JsonAware(PropertyEquality):
def json(self):
return json.dumps(self, cls=GenericEncoder)
@classmethod
def from_json(cls, json):
return cls(**json)
class ExchangeRatesEncoder(json.JSONEncoder):
def default(self, obj):
d = obj.__dict__.copy()
d['from'] = d['frm']
del d['frm']
return d
class ExchangeRates(JsonAware):
def __init__(self, frm, to, rate):
self.frm = frm
self.to = to
self.rate = rate
def json(self):
return json.dumps(self, cls=ExchangeRatesEncoder)
@classmethod
def from_json(cls, json):
d = json.copy()
d['frm'] = d['from']
del d['from']
return cls(**d)
# Test
a = ExchangeRates('a', 'b', 1.23)
print(a.json())
jdict = {"from": "z", "to": "y", "rate": 4.56, }
b = ExchangeRates.from_json(jdict)
print(b.json())
Run Code Online (Sandbox Code Playgroud)
典型输出
{"from": "a", "to": "b", "rate": 1.23}
{"from": "z", "to": "y", "rate": 4.56}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4542 次 |
| 最近记录: |