如何将关键字用作变量名?

use*_*009 7 python keyword

我有以下类与变量from,torate.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)

Psi*_*man 5

为您的首选名称添加一个下划线: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)


PM *_*ing 2

正如评论中提到的,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)