Skip to content

Commit

Permalink
First commit
Browse files Browse the repository at this point in the history
  • Loading branch information
geduldig committed Feb 2, 2013
1 parent 3905245 commit ceacba2
Show file tree
Hide file tree
Showing 11 changed files with 901 additions and 3 deletions.
9 changes: 9 additions & 0 deletions CHANGES.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
v0.1.0, 01 Jan 2013 -- Initial release.

v0.1.1, 08 Jan 2013 -- Added cache for Google geocoder

v0.1.2, 20 Jan 2013 -- Improved exception handling for less fragile connections to twitter.com.
Streaming 'location' option now uses the API's 'locations' parameter.
Dynamic throttling of Google geocode requests to not exceed rate limit.

v1.0.0, 30 Jan 2013 -- Uploaded to github.
11 changes: 11 additions & 0 deletions MANIFEST
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
# file GENERATED by distutils, do NOT edit
CHANGES.txt
README.txt
setup.py
twittergeo/Geocoder.py
twittergeo/SearchGeo.py
twittergeo/SearchPics.py
twittergeo/StreamGeo.py
twittergeo/StreamPics.py
twittergeo/__init__.py
twittergeo/credentials.txt
75 changes: 72 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,73 @@
TwitterGeo
==========
### UNDER DEVELOPMENT ###

Scripts for geocoding tweets and for downloading images embedded in tweets.
_Expected release date is sometime in early February 2013_

---

### TwitterGeo ###

_Scripts for geocoding tweets and for downloading images embedded in tweets._

TwitterGeo contains command line scripts for geocoding tweets and extracting embedded images from tweets from twitter.com. The scripts take one or more search words as command line arguments. The scripts download old tweets using Twitter's REST API and download new tweets using Twitter's Streaming API.

About 1% or 2% of tweets contain latitude and longitude. Of those tweets that do not contain coordinate data, about 60% have the user's profile location, a descriptive text field that may or not be accurate. Using Google's Maps API, we can geocode these tweets, which locates about half of all tweets, a portion of which are suspect.

Use the location option to restrict searches to a geographic location. Twitter returns tweets that either contain geocode in the location region or tweets from users whose profile location is in the specified region.

Google does not require autentication, but it does enforce a daily limit of about 2,500 requests per day and about 10 requests per second.

The Twitter API's require OAuth credentials which you can get by creating an application on dev.twitter.com. Once you have your OAuth secrets and keys, copy them into twittergeo/credentials.txt. Alternatively, specify the credentials file on the command line.

Twitter restricts searching old tweets to within roughly the past week. Twitter also places a bandwidth limit on searching current tweet, but you will notice this only when you are searching a popular word. When this limit occurs the total number of skipped tweets is printed and the connection is maintained.

# Features #

*The following modules run as command line scripts and write tweets to the console.*

### SearchGeo ###

Prints old tweets and their location information and coordinates when possible.

### StreamGeo ###

Prints new tweets and their location information and coordinates when possible.

### SearchPics ###

Prints old tweets, their coordinates and URLs of any embedded photos. To download the photos use the -photo_dir option. To get tweets only from a specific geographic region use the -location.

### StreamPics ###

Prints new tweets, their coordinates and URLs of any embedded photos. To download the photos use the -photo_dir option. To get tweets only from a specific geographic region use the -location.

*These are utility modules.*

### Geocoder ###

A wrapper for pygeocoder that provides a few Twitter helper methods. It adds throttling to respect Google's daily quota and rate limit. It also provides a caching mechanism for storing geocode lookups to a text file. The caching is only partially effective because user can enter their location in any format.

# Installation #


1. On a command line, type:

`pip install twittergeo`

2. Either copy your OAuth consumer secret and key and your access token secret and key into twittergeo/credentials.txt, or copy them into another file which you will specify on the command line. See credentials.txt for the expected file format.

3. Then, run a script type with '-m' option, for example:

`python -m twittergeo.StreamGeo zzz`
`python -m twittergeo.StreamGeo zzz -oauth ./my_credentials.txt`

# External Dependencies #

This package uses the following external packages.

* twitterapi - for downloading tweets
* pygeocoder - for geo-referencing using Google's Maps service
* fridge - for caching latitudes and longitudes in a persistant dict

# Contributors #

Jonas Geduldig
17 changes: 17 additions & 0 deletions setup.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
from distutils.core import setup

setup(
name='TwitterGeo',
version='1.0.0',
author='Jonas Geduldig',
author_email='[email protected]',
packages=['twittergeo'],
package_data={'': ['credentials.txt']},
url='https://github.com/geduldig/twittergeo',
download_url = 'https://github.com/gedldig/twittergeo/tarball/1.0.0',
license='MIT',
keywords='twitter',
description='Command line scripts for geocoding old and new tweets from twitter.com and for downloading embedded photos.',
long_description=open('README.txt').read(),
install_requires = ['twitterapi', 'pygeocoder', 'Fridge']
)
Loading

0 comments on commit ceacba2

Please sign in to comment.