Python: UnicodeEncodeError: кодек 'latin-1' не может кодировать символ

Я нахожусь в сценарии, где я вызываю api и на основе результатов из api я вызываю базу данных для каждой записи, которую я в api. Мои строки возврата вызова api, и когда я вызываю базу данных для элементов, возвращаемых api, для некоторых элементов я получаю следующую ошибку.

Traceback (most recent call last):
  File "TopLevelCategories.py", line 267, in <module>
    cursor.execute(categoryQuery, {'title': startCategory});
  File "/opt/ts/python/2.7/lib/python2.7/site-packages/MySQLdb/cursors.py", line 158, in execute
    query = query % db.literal(args)
  File "/opt/ts/python/2.7/lib/python2.7/site-packages/MySQLdb/connections.py", line 265, in literal
    return self.escape(o, self.encoders)
  File "/opt/ts/python/2.7/lib/python2.7/site-packages/MySQLdb/connections.py", line 203, in unicode_literal
    return db.literal(u.encode(unicode_literal.charset))
UnicodeEncodeError: 'latin-1' codec can't encode character u'\u2013' in position 3: ordinal not in range(256)

Сегмент моего кода, на который ссылается указанная выше ошибка:

         ...    
         for startCategory in value[0]:
            categoryResults = []
            try:
                categoryRow = ""
                baseCategoryTree[startCategory] = []
                #print categoryQuery % {'title': startCategory}; 
                cursor.execute(categoryQuery, {'title': startCategory}) #unicode issue
                done = False
                cont...

После некоторого поиска в Google я попробовал следующее в командной строке, чтобы понять, что происходит ...

>>> import sys
>>> u'\u2013'.encode('iso-8859-1')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
UnicodeEncodeError: 'latin-1' codec can't encode character u'\u2013' in position 0: ordinal not in range(256)
>>> u'\u2013'.encode('cp1252')
'\x96'
>>> '\u2013'.encode('cp1252')
'\\u2013'
>>> u'\u2013'.encode('cp1252')
'\x96'

Но я не уверен, что будет решение для преодоления этой проблемы. Также я не знаю, какова теория, лежащая в основе encode ('cp1252') , было бы здорово, если бы я смог получить некоторое объяснение того, что я пробовал выше.

12
задан add-semi-colons 28 November 2011 в 00:12
поделиться