This repo contains the software written to automate the procces of "sustained" search/scraping on Twitter using R and the Twitter Developer API. Not only provides the software, but here I'll discuss something about automation, hardware and deploying, providing an extensive guide aiming less experienced users.
Read the rest of this README.md
file for more information about the thought procces and use guide. I'm far from beeing an experienced programmer so feel free to contribue and address issues to help me on this project. Also you can contact me on Twitter (@ianvaraujo) or email ([email protected]).
The biggest drawback while using the Twitter Developer API for scraping tweets and performing social media research in social sciences is the time span limitation. Both the R (rtweet) and Python (tweepy) libraries, that interact with the API, fall under the problem of having access only to tweets posted 7-9 days in the past. This limits the study possibilitys of researchers who intend to work using this methodology (myself included). Twitter provides a premium API wich allows to search 30 days in the past or even the entire Twitter arquive (since ≅ 2007) depending on wich subscription you choose.
I was working on a project related to Universal Basic Income policys and as part of my job I had to search for tweets, from both citizens and politicians, mencioning the topic "basic income". Because I also had other tasks inside this project to focus on, such as reading and writing, I started developing some way to search this tweets with less effort as possible (i.e as automatic as possible).
Here I doccument this journey and the current state of development for this application that I intend to share and open for contribution.
The main goal here, besides sharing my first open source project, is to make this script easy to use and avaible for people who don't necessarily master R or computational tools for applied humanities research.
The idea behind it is very simple. You need to be able to search tweets every 3-6 days communicatiing with the API via rtweet
and store this data somewhere. You could make a script and run it manually, sure! But this script implements a way to make it automatic, plus searching various terms at the same time. Also you need figure out a way to make the data collection as efficient as possible, not scraping duplicate information and storing it on a reliable place and format.
The second step, after writing the software, is to figure out a way of automating the task of running the R script. On your local machine you could use any task scheduler to program a certain time and period to run your code. For this I used cron
on Ubuntu.
The problem is: you'll need your computer on all the time or at least make sure it will be on when the code is set to run. This results on a lot of problems, because you will often forget to turn it on. The solution is to run the code on a server or a cloud service, making sure your code will always run without exceptions and no tweet will be lost. For this I recommend repourposing an old computer/laptop and use it as a server, installing Debian or Ubuntu. Another option is to use a Raspberry Pi wich will reduce the energy consuption. I'll talk about both of this methods below.
Using this method (software + server) you will be able to cummulate a great amount of data, the outcome of days or months of search, to build a reliabre source of information to your research or project. You can run it for as long as you can and editing the query-config.json
you'll be able to add and remove terms changing the subject of your searh maintaining the data collected previously.
This script was idealized to minimize human interaction and the obligation to run it manually. After cloning this project I recommend following 3 simples steps to set everything up and start scraping.
Create a Twitter Developer Account in order to gain access to the API (if don't have one already)
Access the config.txt
file on the config folder and insert the keywords/terms to search (don't use quotation marks and write on term for each line)
Access the api-config.json
file on the config folder and insert your personal credentials to authorize the rtweet
to send requests to the API using your user account
This optional: start a sometype of task scheduler to automate the process of running the R script every 3 days or every week