Сплит и нелатинские строки в Python 2.X - PullRequest
1 голос
/ 01 декабря 2011

Пример:

# -*- coding: utf-8 -*-
my_str = u'Строка ^ с ^ разделителями!' # Russian letters
print my_str.replace(' ', '')
print my_str.replace(' ', '').split('^')

Результат:

Строка^с^разделителями!
[u'\u0421\u0442\u0440\u043e\u043a\u0430 ', u' \u0441 ', u' \u0440\u0430\u0437\u0434\u0435\u043b\u0438\u0442\u0435\u043b\u044f\u043c\u0438!']

Пожалуйста, помогите.Как я могу показать «нормальные» строки после разбиения?

PS Кодировка файла-сценария - utf8

1 Ответ

4 голосов
/ 01 декабря 2011

Эти являются обычными строками, вы просто видите их внутреннее представление (поскольку вы не печатаете строку, вы печатаете список во втором примере). У

for s in my_str.replace(' ', '').split('^'):
    print s

и вы увидите. И наоборот, попробуйте

print repr(my_str.replace(' ', ''))

и посмотрим, что будет потом.

...