递归似乎是一种解决方法,但是,如果您使用的是python
2.xx,则要检查
unipre,而不是
str(
str类型代表一个字符串字符串,类型代表一个
unipreUnipre字符字符串;两者都不继承自另一个)并且它是unipre类型的字符串,在解释器中显示,前面带有au)。
在您发布的代码中也有一点语法错误(结尾
elif:应该是
else),并且在输入是字典或列表的情况下,您不会返回相同的结构。(对于字典,您将返回最终键的转换版本;对于列表,您将返回final元素的转换版本。都不对!)
您还可以通过理解使您的代码漂亮且具有Python风格。
那么,这就是我的建议:
def convert(input): if isinstance(input, dict): return {convert(key): convert(value) for key, value in input.iteritems()} elif isinstance(input, list): return [convert(element) for element in input] elif isinstance(input, unipre): return input.enpre('utf-8') else: return input
最后一件事。我更改
enpre('ascii')为
enpre('utf-8')。我的理由如下:以ASCII编码时,任何仅包含ASCII字符集中的字符的unipre字符串都将由与utf-8编码时相同的字节字符串表示,因此使用utf-8而不是ASCII不会破坏任何内容,并且只要您要处理的unipre字符串仅使用ASCII字符,更改就不会可见。但是,此更改扩展了功能的范围,使其能够处理整个unipre字符集中的字符串,而不仅仅是ASCII字符集(如有必要)。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)