Рассмотрим:
$ 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 в исходном коде?
В заголовке источника вы можете объявить:
#!/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.
Не забудьте проверить, правильно ли ваш текстовый редактор кодирует ваш код в UTF-8.
В противном случае у вас могут появиться невидимые символы, которые не интерпретируются как UTF-8.