sql >> Database teknologi >  >> NoSQL >> MongoDB

Hvordan kan jeg forbruge tweets fra Twitters streaming-api og gemme dem i mongodb

Her er et eksempel:

import json
import pymongo
import tweepy

consumer_key = ""
consumer_secret = ""
access_key = ""
access_secret = ""

auth = tweepy.OAuthHandler(consumer_key, consumer_secret)
auth.set_access_token(access_key, access_secret)
api = tweepy.API(auth)


class CustomStreamListener(tweepy.StreamListener):
    def __init__(self, api):
        self.api = api
        super(tweepy.StreamListener, self).__init__()

        self.db = pymongo.MongoClient().test

    def on_data(self, tweet):
        self.db.tweets.insert(json.loads(tweet))

    def on_error(self, status_code):
        return True # Don't kill the stream

    def on_timeout(self):
        return True # Don't kill the stream


sapi = tweepy.streaming.Stream(auth, CustomStreamListener(api))
sapi.filter(track=['Gandolfini'])

Dette vil skrive tweets til mongodb test database, tweets samling.

Håber det hjælper.



  1. Kombiner to OR-forespørgsler med AND i Mongoose

  2. MongoDB bedste praksis for referencer

  3. Azure Redis Cache - Flere fejl TimeoutException:Timeout udfører GET {key}

  4. Bulk mongodb indsæt i Meteor eller Node