仲間の愛好家にご挨拶:
特定の半径で特定のツイートを検索し、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']])