[Beginner] How to use the 'requests' library in Python to get information about cryptocurrency

in #python8 years ago (edited)

Introduction

<p dir="auto">The <code>requests library in Python is a powerful tool in order to communicate with online resources and build useful applications. In this short tutorial I will show you have to get cryptocurrency data such as the conversion of Bitcoin to U.S. dollar in Python. Being able to programmatically get data regarding cryptocurrencies can be very useful and lead to more informed decisions regarding trading.<br /> <img src="https://images.hive.blog/768x0/http://i.imgur.com/m8kiaR2.png" srcset="https://images.hive.blog/768x0/http://i.imgur.com/m8kiaR2.png 1x, https://images.hive.blog/1536x0/http://i.imgur.com/m8kiaR2.png 2x" /><br /> <em>We will be using the Python programming language <h2>Initial Setup <p dir="auto">For this tutorial we will be using the <a href="https://www.python.org/" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">Python programming language. Use of the language will be very minimal in order to get our desired result so you do not need to know very much about programming at all. To test that python is installed simply type <code>python in your system's terminal or command prompt and press enter. You should see something like this: <pre><code>Python 2.7.13 (default, Dec 18 2016, 07:03:39) [GCC 4.2.1 Compatible Apple LLVM 8.0.0 (clang-800.0.42.1)] on darwin Type "help", "copyright", "credits" or "license" for more information. >>> <p dir="auto">This is the Python interpreter you can use to test out various Python language features. Type <code>quit() and press enter to leave the interpreter. <h2>Installing the <code>requests library <p dir="auto">In order to grab data about a cryptocurrency we have to make a request to some website in order to grab that data. Every time you open up a browser and look for information you are making multiple requests. The requests that execute and grab information are called <code>GET requests and the requests where a user is posting data to a server such as login information or address information are called <code>POST requests, you can read more about these requests, you can read more about the different types of requests <a href="https://www.w3schools.com/tags/ref_httpmethods.asp" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">here. <p dir="auto">To install the requests library for python, in a terminal or command prompt window run:<br /> <code>pip install requests <h2>Grabbing the information <p dir="auto">Many websites have these things called application programming interfaces (APIs) which allows people to interface with their data and grab specific information by making requests to their website. Luckily for us, <a href="https://www.cryptocompare.com/api/" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">CryptoCompare has a nice API which lets us grab accurate information regarding cryptocurrency prices by making requests. <h2>Let's get started <p dir="auto">Create a new file in any folder and call it <code>get_bitcoin_price.py open that file in your favorite text-editor, personally I use <a href="http://www.vim.org/" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">Vim. The first thing we're going to do is make the program aware of the requests library by importing it in, to do this we do: <pre><code># This is how you write a comment in python # The below line imports the requests library import requests <h2>Finding the right endpoint to hit <p dir="auto">We need to make a request to get the specific information we need in this case getting the US dollar or Euro conversion rate of Bitcoin. A quick glance at the documentation on the <a href="https://www.cryptocompare.com/api/#-api-data-price-" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">CryptoCompare API website shows us that the following endpoint will get us what we need: <pre><code>https://min-api.cryptocompare.com/data/price?fsym=BTC&tsyms=USD,EUR <p dir="auto">Let's break this down, you might have noticed that there are often <code>? in the URL address bar on some websites, this denotes the beginning of listing URL parameters. Think of going to this link, as running a function and the things after the question mark being the variables you pass into that function. In this case <strong>fsym is the <strong>from currency variable, and <strong>tsyms is the <strong>to currencies variable, and as you may be able to tell we are converting from Bitcoin to US dollar and EUR. Try pasting this link into a web browser and see what you get, you should get something like this: <pre><code>{ USD: 971.57, EUR: 887.61 } <p dir="auto">What we just did was made a request in our browser to the API and received data regarding the current conversion rates for Bitcoin to USD and EUR. If we added <strong>INR to the tsyms list in our URL we could also get the Indian Rupee conversion rate. <p dir="auto">Now that we have the right endpoint lets try grabbing in Python so we don't have to open a web browser every time. <h2>Making a request in Python <p dir="auto">Open <code>get_bitcoin_price.py again, we are now going to try to make a <code>GET request to the endpoint we learned about earlier. The file should now look like this: <pre><code># This is how you write a comment in python # The below line imports the requests library import requests # make a GET request to the endpoint and store the response in a variable called response response = requests.get("https://min-api.cryptocompare.com/data/price?fsym=BTC&tsyms=USD,EUR") # print the response text print(response.text) <p dir="auto">Save the file and close <h2>Running the program <p dir="auto">To run the program in your command prompt or terminal simply type:<br /> <code>python get_bitcoin_price.py<br /> And you should get the following result: <pre><code>{"USD":973.07,"EUR":886.96} <h2>Conclusion <p dir="auto">I hope this has been a very informative introduction in making requests to get useful data from an API for you, I highly recommend reading more regarding the CryptoCompare API, and utilizing its full ability to stay informed when trading. For those of you who are more technically advanced I definitely plan on doing more involved tutorials in the future, if you have any suggestions please comment below. <p dir="auto"><em>Cheers<br /> <em>~Np
Sort:  

Excellent tutorial on using APIs in Python programs, thanks!

I need to play with this as I have a Pi that could be showing me prices. Are you using Python 2.7? Any reason to not use 3?

I usually switch between the two depending on what libraries I'm using. Some libraries are only well supported on Python 2.7, here is a detailed page describing the benefits of one over the other. Thanks!

I've stuck with 3 for my personal projects and not had any issues. I expect there's less and less reasons to use 2 as things get ported.

This is an excellent tutorial, I've given you a follow mate.