userStream {streamR} | R Documentation |
Connect to Twitter Streaming API and return messages for a single user.
Description
userStream
opens a connection to Twitter's Streaming API
that will return statuses specific to the authenticated user. The output
can be saved as an object in memory or written to a text file.
Usage
userStream(file.name = NULL, with = "followings", replies = NULL,
track = NULL, locations = NULL, timeout = 0, tweets = NULL,
oauth = NULL, verbose = TRUE)
Arguments
file.name |
string, name of the file where tweets will be written. "" indicates output to the console, which can be redirected to an R object. If the file already exists, tweets will be appended (not overwritten). |
with |
string, detault is "followings", which will stream messages from accounts the authenticated user follow. If set to "user", will only stream messages from authenticated user. See the |
replies |
string, default is See the |
track |
string or string vector containing keywords to track. See the track parameter information in the Streaming API documentation for details: https://developer.twitter.com/en/docs/tweets/filter-realtime/guides/basic-stream-parameters. |
locations |
numeric, a vector of longitude, latitude pairs (with the southwest corner coming first) specifying sets of bounding boxes to filter statuses by. See the locations parameter information in the Streaming API documentation for details: https://developer.twitter.com/en/docs/tweets/filter-realtime/guides/basic-stream-parameters |
timeout |
numeric, maximum length of time (in seconds) of connection to stream.
The connection will be automatically closed after this period. For example, setting
|
tweets |
numeric, maximum number of tweets to be collected when function is called.
After that number of tweets have been captured, function will stop. If set to |
oauth |
an object of class |
verbose |
logical, default is |
Details
This function provides access to messages for a single user.
The set of messages to be returned can include the user's tweets and/or replies, and public statuses published by the accounts the user follows, as well to replies to those accounts.
Tweets can also be filtered by keywords and location, using the track
and locations
arguments.
The total number of actual tweets that are captured might be lower than the number of tweets requested because blank lines, deletion notices, and incomplete tweets are included in the count of tweets downloaded.
Note that when no file name is provided, tweets are written to a temporary file, which is loaded in memory as a string vector when the connection to the stream is closed.
Author(s)
Pablo Barbera pablo.barbera@nyu.edu
See Also
filterStream
, sampleStream
, parseTweets
Examples
## Not run:
## The following example shows how to capture a user's home timeline
## with the Streaming API and using authentication via the ROAuth
## package, with fictitious consumerkey and consumer secret.
## You can obtain your own at dev.twitter.com
library(ROAuth)
requestURL <- "https://api.twitter.com/oauth/request_token"
accessURL <- "https://api.twitter.com/oauth/access_token"
authURL <- "https://api.twitter.com/oauth/authorize"
consumerKey <- "xxxxxyyyyyzzzzzz"
consumerSecret <- "xxxxxxyyyyyzzzzzzz111111222222"
my_oauth <- OAuthFactory$new(consumerKey=consumerKey,
consumerSecret=consumerSecret, requestURL=requestURL,
accessURL=accessURL, authURL=authURL)
my_oauth$handshake(cainfo = system.file("CurlSSL", "cacert.pem", package = "RCurl"))
## Alternatively, it is also possible to create a token without the handshake:
my_oauth <- list(consumer_key = "CONSUMER_KEY",
consumer_secret = "CONSUMER_SECRET",
access_token="ACCESS_TOKEN",
access_token_secret = "ACCESS_TOKEN_SECRET")
## Capturing 10 tweets from a user's timeline
userStream( file.name="my_timeline.json", with="followings",
tweets=10, oauth=my_oauth )
## End(Not run)