我在我的Python代码中使用名为Storm的Active Record来检索MySQL数据库上的一些记录。
问题是:我的表在'utf8_unicode_ci'中,但是当我检索对象时,我得到'latin-1'属性,所以我需要做object.attr.decode('latin-1')。encode('utf- 8'),这是不是总是工作 - 抛出一些例外。
我的问题:这是一个python行为?一个MySQL的行为?与风暴有关的东西?
代码:
Storm.conn(user=db_user,db=db_name, passwd=db_passwd)
events = Event.select('*',status='=2',date_end='>=NOW()')
for event in events:
now = datetime.datetime.now().strftime("%Y-%m-%d %H:%M")
try:
#here we need only utf-8 strings
conn.index({"title": event.get_title(), "local": event.get_local(), "url": event.getUrl(), "description": event.get_description(), "artists": event.get_artists(), "tags": event.get_tags(), "picture": event.get_Picture(), "type": event.get_type(), 'date_begin': event.get_date_begin(), 'date_end': event.get_date_end(), '_ttl': event.get_ttl()}, "wf", "event", event.id)
print 'Indexed - '+now+': '+str(event.id)
except Exception,error:
print 'Error - '+now+': '+str(event.id)+" - "+str(error)