Thing 14: APIs For Use In Research – The Nuts And Bolts

Ever stop to think about how the apps on your mobile phone or tablet receive and exchange data over the Internet? The next time you check your Facebook app, look for directions using Google maps, or do your online banking, chances are these are all happening using an Application Programming Interface (or API for short). In this post, Greg D’Arcy demystifies the wonderful world of APIs. 

Getting started

APIs work using the underlying protocols of the Internet that send data from one network device to another. So, when you open an app on your phone it sends a request for data to a server somewhere on the Internet. The server then interprets your request, and sends back some data to display on your phone. It’s no wonder that APIs are often described as the glue that holds the Internet together.  

That Thing you do: integration into practice

APIs provide researchers from all corners of academia with a way to access online platforms for data – platforms that can be used to examine social attitudes and trends, political exchanges, social interactions, and a wealth of other social phenomena. For scholars in the humanities and the social sciences, the National Library’s Trove website has a wealth of resources in the form of books, digitised newspaper articles, maps, government reports, and heritage records.  

The fabulous A/Prof. Tim Sherratt has put together something he calls his GLAM Workbench, which uses the Trove API to download and explore the contents of Trove using Jupyter notebooks. In case you’ve never heard of them before, Jupyter notebooks let you combine text, images, and live code in a single web page that analyses and visualises your data.

Source: Getting Started, Introducing Jupyter notebooks. https://glam-workbench.github.io/getting-started/ Accessed 15 July 2020.

Considerations

Not all APIs work in the same way, and most have strict requirements for what you can and can’t do with the data you collect. Some issues you’ll need to consider include: 

  • Authentication. Collecting data through APIs is only possible if the data collection programs are authorised to do so. Most APIs typically have some sort of authentication (or access permission) in place to request and access their data. To use an API, you need to register an account where youre issued with an API Key or Token. These are long strings of numbers and letters that allow you to query and receive data back from the API. 
  • Rate and access limits. Many APIs are rate limited, which means that you can only send a certain number of requests per hour. For example, the standard free Twitter API only lets you collect tweets from the past 7-10 days, and doesn’t provide mechanisms to work with historical tweets. If you go over your rate limit, you often have to wait a while before performing another request. 
  • Data formatsWhile we as humans can easily interpret information displayed for us on a web page or mobile app, computers need more help. Instead of sending back a nicely formatted web page, APIs deliver data in a digital form that computers can understand (which is often referred to as machine-readable data). 
  • Privacy and ethicsOne of the most important purposes of research ethics is to protect research participants, and ethical issues are a major consideration in any form of online researchThe question of whether public tweets are by default public data is an ethical issue that is contested. Most API providers have some Terms of Service (TOS) agreement in place to access their data. However, it’s important not to confuse TOS compliance with a human subjects compliance or privacy protection.  

Learn more

  • If you’d like to start working with Jupyter notebooks, head over to Tim Sherratt’s GLAM Workbench. As well as Trove, there are notebooks to access data from a number of other Galleries, Libraries, Archives and Museums (GLAM).  
  • IFTTT (If This Then That) is a free service that lets you stitch different APIs and services together. For example, you can back up your Instagram photos to Dropbox, or save tweets with a particular hashtag to a Google spreadsheet 
  • JSON (JavaScript Object Notation) is standard data format APIs use to transmit data. The W3Schools website has some great tutorials on how to use JSON 

References

Ignatow, Gabe & Mihalcea, Rada (2017). Text Mining: A Guidebook for the Social Sciences. DOI: https://dx.doi.org/10.4135/9781483399782  

Janetzko, Dietmar (2018). The Role of APIs in Data Sampling from Social Media. The SAGE Handbook of Social Media Research Methods. DOI: http://dx.doi.org/10.4135/9781473983847  

Sherratt, Tim (2019). Introducing APIsZenodo. DOI: http://doi.org/10.5281/zenodo.3545007  

Stewart, Bonnie (2018). Twitter as Method: Using Twitter as a Tool to Conduct Research. The SAGE Handbook of Social Media Research Methods. DOI: http://dx.doi.org/10.4135/9781473983847  

About the author

Greg D’Arcy is an Informatics Specialist and Administrator of the Social and Cultural Informatics Platform (SCIP) 

 

Want more from 23 Research Things? Sign up to our mailing list to never miss a post.

 

Image: ThisIsEngineering from Pexels


Leave a Reply

Your email address will not be published. Required fields are marked *