Skip to main content

Python wrapper around the CoinGecko API

Project description

CoinGecko API wrapper

PyPi Version

Python3 wrapper around the CoinGecko API (V3)

Installation

PyPI

pip install pycoingecko

or from source

git clone https://github.com/man-c/pycoingecko.git
cd pycoingecko
python3 setup.py install

Usage

from pycoingecko import CoinGeckoAPI
cg = CoinGeckoAPI()

Examples

The required parameters for each endpoint are defined as required (mandatory) parameters for the coresponding functions. Any optional parameters can be also passed using same names, as defined in CoinGecko API doc (https://www.coingecko.com/api/docs/v3)

Lists are also supported as input for multiple-valued comma-separated parameters (e.g. see /simple/price usage examples).

Usage examples:

# /simple/price endpoint with the required parameters
>>> cg.get_price(ids='bitcoin', vs_currencies='usd')
{'bitcoin': {'usd': 3462.04}}

>>> cg.get_price(ids='bitcoin,litecoin,ethereum', vs_currencies='usd')
# OR (lists can be used for multiple-valued arguments)
>>> cg.get_price(ids=['bitcoin', 'litecoin', 'ethereum'], vs_currencies='usd')
{'bitcoin': {'usd': 3461.27}, 'ethereum': {'usd': 106.92}, 'litecoin': {'usd': 32.72}}

>>> cg.get_price(ids='bitcoin,litecoin,ethereum', vs_currencies='usd,eur')
# OR (lists can be used for multiple-valued arguments)
>>> cg.get_price(ids=['bitcoin', 'litecoin', 'ethereum'], vs_currencies=['usd', 'eur'])
{'bitcoin': {'usd': 3459.39, 'eur': 3019.33}, 'ethereum': {'usd': 106.91, 'eur': 93.31}, 'litecoin': {'usd': 32.72, 'eur': 28.56}}

# optional parameteres can be passed as defined in the API doc (https://www.coingecko.com/api/docs/v3)
>>> cg.get_price(ids='bitcoin', vs_currencies='usd', include_market_cap='true', include_24hr_vol='true', include_24hr_change='true', include_last_updated_at='true')
{'bitcoin': {'usd': 3458.74, 'usd_market_cap': 60574330199.29028, 'usd_24h_vol': 4182664683.6247883, 'usd_24h_change': 1.2295378479069035, 'last_updated_at': 1549071865}}

API documentation

https://www.coingecko.com/api/docs/v3

Endpoints included

  • ping
    • /ping (Check API server status)
      cg.ping()
      
  • simple
    • /simple/price (Get the current price of any cryptocurrencies in any other supported currencies that you need)
      cg.get_price()
      
    • /simple/token_price/{id} (Get current price of tokens (using contract addresses) for a given platform in any other currency that you need)
      cg.get_token_price()
      
    • /simple/supported_vs_currencies (Get list of supported_vs_currencies)
      cg.get_supported_vs_currencies()
      
  • coins
    • /coins/list (List all supported coins id, name and symbol (no pagination required))
      cg.get_coins_list()
      
    • /coins/markets (List all supported coins price, market cap, volume, and market related data (no pagination required))
      cg.get_coins_markets()
      
    • /coins/{id} (Get current data (name, price, market, ... including exchange tickers) for a coin)
      cg.get_coin_by_id()
      
    • /coins/{id}/tickers (Get coin tickers (paginated to 100 items))
      cg.get_coin_ticker_by_id()
      
    • /coins/{id}/history (Get historical data (name, price, market, stats) at a given date for a coin)
      cg.get_coin_history_by_id()
      
    • /coins/{id}/market_chart (Get historical market data include price, market cap, and 24h volume (granularity auto))
      cg.get_coin_market_chart_by_id()
      
    • /coins/{id}/market_chart/range (Get historical market data include price, market cap, and 24h volume within a range of timestamp (granularity auto))
      cg.get_coin_market_chart_range_by_id()
      
    • /coins/{id}/status_updates (Get status updates for a given coin (beta))
      cg.get_coin_status_updates_by_id()
      
  • contract
    • /coins/{id}/contract/{contract_address} (Get coin info from contract address)
      cg.get_coin_info_from_contract_address_by_id()
      
    • /coins/{id}/contract/{contract_address}/market_chart/ (Get historical market data include price, market cap, and 24h volume (granularity auto) from a contract address)
      cg.get_coin_market_chart_from_contract_address_by_id()
      
    • /coins/{id}/contract/{contract_address}/market_chart/range (Get historical market data include price, market cap, and 24h volume within a range of timestamp (granularity auto) from a contract address)
      cg.get_coin_market_chart_range_from_contract_address_by_id()
      
  • exchanges (beta)
    • /exchanges (List all exchanges)
      cg.get_exchanges_list()
      
    • /exchanges/list (List all supported markets id and name (no pagination required))
      cg.get_exchanges_id_name_list()
      
    • /exchanges/{id} (Get exchange volume in BTC and top 100 tickers only)
      cg.get_exchanges_by_id()
      
    • /exchanges/{id}/tickers (Get exchange tickers (paginated))
      cg.get_exchanges_tickers_by_id()
      
    • /exchanges/{id}/status_updates (Get status updates for a given exchange (beta))
      cg.get_exchanges_status_updates_by_id()
      
    • /exchanges/{id}/volume_chart (Get volume_chart data for a given exchange (beta))
      cg.get_exchanges_volume_chart_by_id()
      
  • finance (beta)
    • /finance_platforms (List all finance platforms)
      cg.get_finance_platforms()
      
    • /finance_products (List all finance products)
      cg.get_finance_products()
      
  • indexes (beta)
    • /indexes (List all market indexes)
      cg.get_indexes()
      
    • /indexes/{id} (Get market index by id)
      cg.get_indexes_by_id()
      
    • /indexes/list (List market indexes id and name)
      cg.get_indexes_list()
      
  • derivatives (beta)
    • /derivatives (List all derivative tickers)
      cg.get_derivatives()
      
    • /derivatives/exchanges (List all derivative exchanges)
      cg.get_derivatives_exchanges()
      
    • /derivatives/exchanges/{id} (Show derivative exchange data)
      cg.get_derivatives_exchanges_by_id()
      
    • /derivatives/exchanges/list (List all derivative exchanges name and identifier)
      cg.get_derivatives_exchanges_list()
      
  • status_updates (beta)
    • /status_updates (List all status_updates with data (description, category, created_at, user, user_title and pin))
      cg.get_status_updates()
      
  • events
    • /events (Get events, paginated by 100)
      cg.get_events()
      
    • /events/countries (Get list of event countries)
      cg.get_events_countries()
      
    • /events/types (Get list of events types)
      cg.get_events_types()
      
  • exchange_rates
    • /exchange_rates (Get BTC-to-Currency exchange rates)
      cg.get_exchange_rates()
      
  • global
    • /global (Get cryptocurrency global data)
      cg.get_global()
      

Test

Run unit tests with:

# after installing pytest using pip3
pytest tests

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pycoingecko-1.2.0.tar.gz (6.6 kB view details)

Uploaded Source

Built Distributions

pycoingecko-1.2.0-py3.7.egg (11.1 kB view details)

Uploaded Egg

pycoingecko-1.2.0-py3-none-any.whl (7.0 kB view details)

Uploaded Python 3

File details

Details for the file pycoingecko-1.2.0.tar.gz.

File metadata

  • Download URL: pycoingecko-1.2.0.tar.gz
  • Upload date:
  • Size: 6.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.6.0 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for pycoingecko-1.2.0.tar.gz
Algorithm Hash digest
SHA256 9e233d98819d3de38bc77db11cb0076cf4499ad971b7d16ded0d18e913f78137
MD5 de0c574ba264ded816b39d1b1dacc170
BLAKE2b-256 d9f83476195ec888a095aad8faca2343829dc9d12ebde5b4d082ab9ddfc2b12f

See more details on using hashes here.

File details

Details for the file pycoingecko-1.2.0-py3.7.egg.

File metadata

  • Download URL: pycoingecko-1.2.0-py3.7.egg
  • Upload date:
  • Size: 11.1 kB
  • Tags: Egg
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.6.0 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for pycoingecko-1.2.0-py3.7.egg
Algorithm Hash digest
SHA256 7696d835dedf7b8db59f79e66f033cbcf1e2a18a69c8e7c957c945eb51cd2a63
MD5 6886c19321233ac2174a28edd9cab281
BLAKE2b-256 925ff3ddf4fd4f6121c08a54587b805ed4a55144cb3682f0223c0f7bd2fa699b

See more details on using hashes here.

File details

Details for the file pycoingecko-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: pycoingecko-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 7.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.6.0 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for pycoingecko-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e6e1b90c1f41ac4235fdab1e68a353c02e9c3d4da44d5b110576e7b411d26768
MD5 b8bc0edf859075166a60b65a0bd05ba6
BLAKE2b-256 d918faa7086fed436b2cf379776988de20653a72fef5fb2445f5d1d2dc1eea1a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page