Skip to content

Scrapy spider for retrieving Mastercard and Visa exchange rates

Notifications You must be signed in to change notification settings

HartBlanc/CardRates

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Photo of wallet with currency and magnifying glass

PEP8 Build Status

CardRates

CardRates is a tool for extracting daily fiat currency exchange rates from public websites. Currently the tool can be used to retrieve rates from two international payment schemes, Visa and Mastercard, with scope for other providers in the future.

Motivation

Exchange rates are publicly available on providers websites and can be retrieved easily for a single currency pair on a single date (e.g. GBP/USD for 1st of Jan 2019). This is useful for determining the rate you were charged for a transaction. However, it is not easy to retrieve data across dates and across many currency pairs. This kind of information is necessary for consumers to make informed choices about which payment scheme to choose to get the best rates for their specific requirements.

Build Status

Tests are currently in development, initial tests for the database client are passing.

Built with

Features

  • Retrieve exchange rates for all available dates and currency pairs
  • Retrieve the set of currently offered settlement currencies from each provider
  • Limited database client api

Getting Started

Database Config 📝

First choose a SQL variant to store the rates in (any SQLAlchemy compatible DB will do). Then create a .env file at the root of CardRates with your Database URL.

$ echo DB_URL=dialect[+driver]://user:password@host/dbname > .env

Note: You may need to install a DB API library to connect to your database. Check the SQLAlchemy docs for supported APIs.

Installing Packages 🐍

In the root directory run:

$ pipenv sync  # include --dev flag for development packages
$ pipenv shell

Create Tables and Generate csv 📝

In the src directory run:

$ python createCSV.py --new # (new flag is for creating a new database)

Code Example

Run Spiders 🕷

In the src directory run:

$ scrapy crawl MCSpider -a in_path=MastercardInput/0.csv
$ scrapy crawl VisaSpider -a in_path=VisaInput/0.csv

Contact

callumjameshart@gmail.com

About

Scrapy spider for retrieving Mastercard and Visa exchange rates

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published