0

仲間の愛好家にご挨拶:

特定の半径で特定のツイートを検索し、csv ファイルで返すことを目的とする twitter-api と統合されたプログラムをデバッグしています。それは動作します....しかし、「UnicodeEncodeError: 'ascii' codec can't encode character u'\u201c' in position 0: ordinal not in range(128)」エラーが発生することがありますが、コードを調整しました範囲外の twitter からの Unicode データを無視するようにします。

では、なぜそのエラーがまだ時々発生するのでしょうか?

以下は、コメントで指定されたテスト入力で実行するコードです。

import urllib2, json, pprint, codecs, unicodedata, csv
## test coordinate input: 29.762778,-95.383056
## test radius 10
## test query: tebow
##Initial user input
city = raw_input("Please enter to 6 decimal places the city\ncoordinates to be searched ex. lat,long: ")
radius = raw_input("Please enter the numeric value of the\nradius in miles you'd like to search ex. 10: ")
term= raw_input("Please enter the search term you wish to query ex. tebow: ")

u = urllib2.urlopen('http://search.twitter.com/search.json?q='+term+'&geocode='+city+','+radius+'mi&page=1&rpp=20')
datares = json.load(u)
##pprint.pprint(datares)

with codecs.open('Geotweets.csv',mode='w', encoding='utf-8',errors='ignore') as cache:
    writer = csv.writer(cache)
    for tweet in datares['results']:
        writer.writerow([tweet['text'], tweet['location'], tweet['created_at'], tweet['from_user']])
4

1 に答える 1

0

で隠れた変換が行われていwriterowます。たとえば、自分でデータをエンコードしますtweet['text'].encode('ascii', 'ignore')

于 2012-05-11T19:06:08.553 に答える