UnicodeDecodeError: Kodek „ascii” nie może dekodować bajtu 0xef w pozycji 1

Mam kilka problemów z kodowaniem łańcucha znaków do UTF-8. Próbowałem wielu rzeczy, w tym używaniastring.encode('utf-8') iunicode(string), ale dostaję błąd:

UnicodeDecodeError: kodek „ascii” nie może dekodować bajtu 0xef w pozycji 1: porządkowa nie w zakresie (128)

To jest mój ciąg:

<code>(。・ω・。)ノ
</code>

Nie widzę, co się dzieje źle, jakikolwiek pomysł?

Edytuj: Problem polega na tym, że drukowanie łańcucha w takiej postaci, w jakiej jest, nie jest wyświetlane prawidłowo. Również ten błąd, gdy próbuję go przekonwertować:

<code>Python 2.7.1+ (r271:86832, Apr 11 2011, 18:13:53)
[GCC 4.5.2] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> s = '(\xef\xbd\xa1\xef\xbd\xa5\xcf\x89\xef\xbd\xa5\xef\xbd\xa1)\xef\xbe\x89'
>>> s1 = s.decode('utf-8')
>>> print s1
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
UnicodeEncodeError: 'ascii' codec can't encode characters in position 1-5: ordinal not in range(128)
</code>

questionAnswers(16)

yourAnswerToTheQuestion