Работа с кодировкой UTF-8 в исходном коде Python

Рассматривать:

$ cat bla.py 
u = unicode('d…')
s = u.encode('utf-8')
print s
$ python bla.py 
  File "bla.py", line 1
SyntaxError: Non-ASCII character '\xe2' in file bla.py on line 1, but no encoding declared; see http://www.python.org/peps/pep-0263.html for details

Как я могу объявить строки UTF-8 в исходном коде?

Ответ 1

В заголовке исходного кода вы можете объявить:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
....

Это описано в PEP 0263:

Тогда вы можете использовать UTF-8 в строках:

#!/usr/bin/env python
# -*- coding: utf-8 -*-

u = 'idzie wąż wąską dróżką'
uu = u.decode('utf8')
s = uu.encode('cp1250')
print(s)

Это объявление не требуется в Python 3, поскольку UTF-8 является исходной кодировкой по умолчанию (см. PEP 3120).

Кроме того, возможно, стоит проверить, что ваш текстовый редактор правильно кодирует ваш код в UTF-8. В противном случае у вас могут быть невидимые символы, которые не интерпретируются как UTF-8.

Ответ 2

Не забудьте проверить, правильно ли кодирует ваш текстовый редактор код в UTF-8.

В противном случае у вас могут быть невидимые символы, которые не интерпретируются как UTF-8.