Pycoingecko
Python wrapper for the CoinGecko API
Install / Use
/learn @man-c/PycoingeckoREADME
CoinGecko API wrapper
Python3 wrapper around the CoinGecko API (V3) 🦎<br> Supports both Public and Pro API:
Installation
PyPI
pip install -U pycoingecko
or from source
git clone https://github.com/man-c/pycoingecko.git
cd pycoingecko
python3 setup.py install
Usage
For free Public API:
- without any demo api key (x-cg-demo-api-key):
from pycoingecko import CoinGeckoAPI cg = CoinGeckoAPI() - 🔑 with a <ins>demo api key</ins>:
from pycoingecko import CoinGeckoAPI cg = CoinGeckoAPI(demo_api_key='YOUR_DEMO_API_KEY')
For Pro API:
- 🔑 with a <ins>pro api key</ins>:
from pycoingecko import CoinGeckoAPI cg = CoinGeckoAPI(api_key='YOUR_PRO_API_KEY')
Examples
The required parameters for each endpoint are defined as required (mandatory) parameters for the corresponding functions.
Any optional parameters can be passed using same names, as defined in CoinGecko API doc (https://www.coingecko.com/en/api/documentation).
For any parameter:
- Lists are supported as input for multiple-valued comma-separated parameters
(e.g. see /simple/price usage examples). - Booleans are supported as input for boolean type parameters; they can be
str('true', 'false'') orbool(True,False)
(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 parameters 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}}
# OR (also booleans can be used for boolean type arguments)
>>> 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/en/api/documentation
📡 Endpoints included
<details><summary>ping</summary> <p>:warning: Endpoints documentation: To make sure that you are using properly each endpoint you should check the API documentation. Return behaviour and parameters of the endpoints, such as pagination, might have changed. <br> Any optional parameters defined in CoinGecko API doc can be passed as function parameters using same parameters names with the API (see Examples above).
-
/ping
Check API server status
cg.ping()
-
[Pro API] 💼 /key
Monitor your account's API usage, including rate limits, monthly total credits, remaining credits, and more
cg.key()
-
/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/list
List all supported coins id, name and symbol (no pagination required)
cg.get_coins_list() -
[Pro API] 💼 /coins/top_gainers_losers
Query the top 30 coins with largest price gain and loss by a specific time duration
cg.get_coin_top_gainers_losers() -
[Pro API] 💼 /coins/list/new
Query the latest 200 coins that recently listed on CoinGecko
cg.get_coins_list_new() -
/coins/markets
List all supported coins price, market cap, volume, and market related data
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}/ohlc
Get the OHLC chart (Open, High, Low, Close) of a coin based on particular coin id
cg.get_coin_ohlc_by_id() -
[Pro API] 💼 /coins/{id}/ohlc/range
Get the OHLC chart (Open, High, Low, Close) of a coin within a range of timestamp based on particular coin id
cg.get_coin_ohlc_by_id_range() -
[Pro API] 👑 /coins/{id}/circulating_supply_chart
Query historical circulating supply of a coin by number of days away from now based on provided coin id
cg.get_coin_circulating_supply_chart() -
[Pro API] 👑 /coins/{id}/circulating_supply_chart/range
Query historical circulating supply of a coin, within a range of timestamp based on the provided coin id
cg.get_coin_circulating_supply_chart_range() -
[Pro API] 👑 /coins/{id}/total_supply_chart
Query historical total supply of a coin by number of days away from now based on provided coin id
cg.get_coin_total_supply_chart() -
[Pro API] 👑 /coins/{id}/total_supply_chart/range
Query historical total supply of a coin, within a range of timestamp based on the provided coin id
cg.get_coin_total_supply_chart_range()
-
/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()
-
/asset_platforms
List all asset platforms (Blockchain networks)
cg.get_asset_platforms() -
[Pro API] 👑 /token_lists/{asset_platform_id}/all.json
Get full list of tokens of a blockchain network (asset platform) that is supported by Ethereum token list standard
cg.get_asset_platform_by_id()
-
/coins/categories/list
List all categories
cg.get_coins_categories_list() -
coins/categories
List all categories with market data
cg.get_coins_categories()
-
/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, 100 tickers per page)
cg.get_exchanges_tickers_by_id()
//: # ( ```python
