最近,我一直在阅读有关Python源代码编码的内容,尤其是PEP 263和PEP 3120 .
我有以下代码:
# coding:utf-8
s = 'abc∂´ƒ©'
ƒ = 'My name is'
ß = '˚ß˙ˆ†ˆ∆ ßå®åø©ˆ'
print('s =', s)
print('ƒ =', ƒ, 'ß =', ß)
这段代码适用于Python3,但在Python2.7中会产生 SyntaxError
.
我知道这可能与源代码编码无关 .
所以,我想知道是否有办法在Python2中支持Unicode变量名 .
总而言之,我也很难弄清楚PEP究竟要解决的实际问题以及我如何(以及在何处)利用所提出的解决方案 . 我已经阅读了相同的讨论,但他们没有提出我的问题的答案,而是对正确语法的解释:
2 回答
不,Python 2仅支持ASCII名称 . 从the language reference:
比较长的Python 3 version,它确实有完整的Unicode名称 .
PEP解决的实际问题是,如果在源文件中出现超过127的字节(比如在unicode字符串中),那么Python无法知道哪个字符是什么意思,因为它可能是任何编码 . 现在它默认被解释为UTF-8,可以通过添加这样的 Headers 来改变它 .
我不认为这两篇文章是关于编码的,例如你的变量名称是Beta符号,但是关于变量值中的编码 .
所以,如果您将代码更改为此示例:
希望这能回答你的问题
问候框架