python - 从 JSON 写入 CSV 时出现 UnicodeEncodeError

标签 python json csv encoding

尝试使用 JSON 写入 CSV 时出现以下错误:

Traceback (most recent call last):
File "twitter_search_csv.py", line 25, in <module>
status['retweet_count'],
UnicodeEncodeError: 'ascii' codec can't encode character u'\u2026' in position 139: ordinal not in range(128)

这是我正在使用的代码:

import requests
import urllib2
from requests_oauthlib import OAuth1
import csv

auth = OAuth1('', '', '', '')
url = 'https://api.twitter.com/1.1/search/tweets.json?q=%23OpeningCeremony'

response = requests.get(url, auth=auth)

data = response.json()['statuses']

with open('olympic_search.csv', 'wb') as csvfile:
    f = csv.writer(csvfile)
    for status in data:
        f.writerow([
            status['id'],
            status['text'],
            status['created_at'],
            status['coordinates'],
            status['user']['id_str'],
            status['retweet_count'],
        ])

最佳答案

显式编码字段。否则 Python 会尝试使用 ascii 编码对其进行编码。

>>> print u'\u2026'.encode('ascii')

Traceback (most recent call last):
  File "<pyshell#2>", line 1, in <module>
    print u'\u2026'.encode('ascii')
UnicodeEncodeError: 'ascii' codec can't encode character u'\u2026' in position 0: ordinal not in range(128)
>>> print u'\u2026'.encode('utf-8')
…

f.writerow([
    status['id'],
    status['text'].encode('utf-8'), # <----
    status['created_at'],
    status['coordinates'],
    status['user']['id_str'],
    status['retweet_count'],
])

关于python - 从 JSON 写入 CSV 时出现 UnicodeEncodeError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21634912/

相关文章:

xml - 使用 XSLT 将此 XML 转换为 JSON

json - Google Places Api 排名=距离 不起作用

javascript - 数据以 JSON 对象的形式传入,如何解析?

python - 读取 CSV 并绘制彩色折线图

python - 如何在CSS中水平显示输入表单?

python - 正在使用 Python 为 Cassandra Dumb 进行 MapReduce?

python - 如何解释 __getattribute__、__getattr__ 的 'weird' 结果?

python - 在 python 中删除字符串中的\x

php - 在接受 CSV 文件时,application/octet-stream 是一种安全的 MIME 类型吗?

java - 带列标题的 StatefulBeanToCsv