Skip to main content

A Python module for Twitter API and OAuth

Project description

These are four contents.

What is changed from version 0.1.0 to 0.2.0

  • Using json data in version 0.2.0

  • You can use more methods in version 0.2.0 than 0.1.0

  • Especially, you can use search methods in version 0.2.0

Required

Twitter_oauth requires Python 2.x superior to 2.5.

These modules are required.

  • oauth2

If you use python 2.5, you also need

  • simplejson

Installation

On Linux.

install simplejson

If you use Python 2.x superior to Python 2.6, skip install simplejson and go to install twitter_oauth

If you use python2.5, you should install simplejson first.

Download simplejson from http://pypi.python.org/pypi/simplejson/

Then, change the directory which contains simplejson file, and

$ tar vxzf simplejson-2.1.1.tar.gz
$ cd simplejson-2.1.1
$ sudo python setup.py install

install twitter_oauth

From PyPI:

$ sudo easy_install twitter_oauth

Tutorial

OAuth

First, you shold have two keys, ‘consumer key’, ‘consumer secret’.

If you don’t have ‘consumer key’ and ‘consumer secret’, you cat get these keys to register your application to Twitter. You cat register your application at next URL.

http://twitter.com/apps

Then, you shold get two keys, ‘oauth_token’, and ‘oauth_token_secret’

To get these keys, you use GetOauth class in this module.

>>> import twitter_oauth

>>> # write your key and secret
>>> consumer_key = '***'
>>> consumer_secret = '***'

>>> get_oauth_obj = twitter_oauth.GetOauth(consumer_key, consumer_secret)

Then, you get ‘oauth_token’ and ‘oauth_token_secret’ by using get_oauth method. This method returns a dictionary that contain ‘consumer key’, ‘consumer secret’, ‘oauth_token’ and ‘oauth_token_secret’

>>> get_oauth_obj.get_oauth()
  Request Token:
  - oauth_token        = ***
  - oauth_token_secret = ***
  Go to the following link in your browser
  http://twitter.com/oauth/authorize?oauth_token=***

  What is the PIN? ***
  Access Token:
  - oauth_token        = ***
  - oauth_token_secret = ***

  You may now access protected resources using the access token above

Api class

Now, you can use twitter_oauth.Api class. To use this class, you can post update, or get friends timeline, etc…

Next example is how to use twitter_oauth.Api class

>>> # import twitter_oauth module
>>> import twitter_oauth

>>> # write yoru consumer_key, consumer_secret,
>>> # oauth_token, oauth_token_secret
>>> consumer_key = '***'
>>> consumer_secret = '***'
>>> oauth_token        = '***'
>>> oauth_token_secret = '***'

>>> # Then, create Api instance

>>> api = twitter_oauth.Api(consumer_key, consumer_secret,
>>>                         oauth_token, oauth_token_secret)

Use get_friends_timeline method. You can get friends timeline to use this method.

>>> friends_timeline = api.get_friends_timeline()
>>> print [stauts.text for status in friends_timeline]

Use get_user_timeline method.
You can get user timeline to use this method.

>>> user_timeline = api.get_user_timeline()
>>> print [stauts.text for status in user_timeline]

Use get_replies method.
You can get replies to use this method.

>>> replies = api.get_replies()
>>> print [stauts.text for status in replies]

Use post_update method You can post message to Twitter.

CAUTION : post_update method shold take a unicode. Especially, you can post a Japanese text.

>>> api.post_update(tweet=u'Hello, Twitter')

Use get_list_status method.

>>> # write username and list name
>>> api.get_list_status(user='username', list_id='listname')
>>> print [status.text for status in api.get_list_status(user="username", list_id="listname")]

Use search method

If you want to show tweets including ‘keyword’,

>>> search_obj = api.search(q='keyword')
>>> print [tweet_info.text for tweet_info in search_obj.results]

If you want to show tweets including ‘keyword’ and ‘anotherkeyword’,

>>> search_obj = api.search(q='keyword anotherkeyword')
>>> print [tweet_info.text for tweet_info in search_obj.results]

If you want to show tweets including ‘keyword’ or ‘anotherkeyword’,

>>> search_obj = api.search(q='keyword OR anotherkeyword')
>>> print [tweet_info.text for tweet_info in search_obj.results]

If you want to show timeline from ‘user’,

>>> search_obj = api.search(q='from:user')
>>> print [tweet_info.text for tweet_info in search_obj.results]

If you want to show tweets to ‘user’, then

>>> search_obj = api.search(q='to:user')
>>> print [tweet_info.text for tweet_info in search_obj.results]

If you want to show tweets from ‘user’ to ‘another’, then

>>> search_obj = api.search(q='from:user to:another')
>>> print [tweet_info.text for tweet_info in search_obj.results]

If you want to search tag,

>>> search_obj = api.search(q='#twitter')
>>> print [tweet_info.text for tweet_info in search_obj.results]

To know more information about a search method, see the next link.

http://dev.twitter.com/doc/get/search

Methods

You can use next methods

  • status

    • post_update()

    • show_status()

    • destroy_status()

  • timeline

    • get_user_timeline()

    • get_friends_timeline()

    • get_replies()

  • list

    • get_list_status()

  • friendship

    • create_friendship()

    • destroy_friendship()

  • user

    • search_user()

    • show_user()

  • search

    • search()

Sample Code

#! /usr/bin/env python
# coding:utf-8

import twitter_oauth

# write your oauth token and oauth token secret
consumer_key = '***'
consumer_secret = '***'

# create GetOauth instance
get_oauth_obj = twitter_oauth.GetOauth(consumer_key, consumer_secret)

# get oauth_token and oauth token secret
key_dict = get_oauth_obj.get_oauth()

# create Api instance
api = twitter_oauth.Api(consumer_key, consumer_secret, key_dict['oauth_token'], key_dict['oauth_token_secret'])


## timeline method

# get friends timeline
print [status.text for status in api.get_friends_timeline()]

# get user timeline
print [status.text for status in api.get_user_timeline()]

# get replies
print [status.text for status in api.get_replies()]


## status method

# post update
api.post_update(tweet=u'Hello, Twitter')

# show status and destroy status
status = api.get_user_timeline()[0]

print api.show_status(id=status.id).text
api.destroy_status(id=status.id)


## friendship method

api.create_friendship(id='twitter')
api.destroy_friendship(id='twitter')


## user method
print api.show_user(id='twitter').screen_name
print [user.screen_name for user in api.search_user(q='twitter')]


## search method

print [tweet_info.text for tweet_info in api.search(q='#twitter').results]

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

twitter_oauth-0.2.0.tar.gz (10.3 kB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page