我有一个 Google App Engine 应用程序,它以多种语言存储数据,例如德语和俄语。为此,我需要将字符串存储为 UTF-8,幸运的是,这是自动完成的,因为我使用了 webapp2.request 处理程序。作为一个初级程序员,这让我避免了编码和解码数据的复杂性。
但是现在我正在尝试将内容写入 CSV 文件,而且对于 csv.writer 命令来说,无论如何编码都是必要的。现在我不确定是否应该解码或编码,但目前我得到的错误如下:
UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-9: ordinal not in range(128)
我正在使用的代码是:
import csv, webapp2, codecs
class AdminShopExport(webapp2.RequestHandler):
def get(self):
shops = Shop.all()
shops.order('name')
self.response.headers['Content-Type'] = 'application/csv'
writer = csv.writer(self.response.out)
writer.writerow(["id", "name", "domain", "category"])
for shop in shops:
writer.writerow([shop.keyname, shop.name, shop.url, shop.category])
关于内容,该错误当前来自以俄语给出的类别。但是如上所述,这些字段中的任何一个都可以包含 UTF-8 字符。处理这个问题的最佳方法是什么?谢谢你的帮助!