DeFinance is a Python library designed to abstract the APIs of various cryptocurrency exchanges and fetch cryptocurrency market data. Currently, it supports spot prices in Binance, Bitget, and OKX exchanges. This library simplifies the process of retrieving cryptocurrency price data by providing a unified interface.
- Fetch spot price data from Binance, Bitget, and OKX.
- Unified interface to handle data retrieval from multiple exchanges.
- Automatic fallback mechanism to fetch data from other exchanges if the symbol is not found in one of the exchange.
To install DeFinance, you can use pip:
pip install definance
Here's a quick example of how to use DeFinance to fetch cryptocurrency price data:
from definance import fetch_price_data, Exchange
To fetch price data from a specific exchange, you can specify the exchange as an argument:
price_data = fetch_price_data('BTC/USDT', Exchange.BINANCE)
print(price_data)
If you do not specify an exchange, DeFinance will attempt to fetch the data from all supported exchanges in the following order: Binance, Bitget, and OKX.
price_data = fetch_price_data('BTC/USDT')
print(price_data)
If the symbol is not found in any of the exchanges, an exception will be raised:
from definance.exceptions import SymbolNotFound
try:
price_data = fetch_price_data('INVALID_SYMBOL')
except SymbolNotFound as e:
print(e)
Fetches the cryptocurrency price data from the specified exchange or from all exchanges if none is specified.
symbol
(str): The symbol of the cryptocurrency. Example: 'BTC/USDT', 'ETH/BTC', 'BTC'.exchange
(Exchange, optional): The exchange to fetch the data from. IfNone
, the function will try to fetch the data from all exchanges.
PriceData
: The price data object containing the fetched price data.
Exchange.BINANCE
Exchange.BITGET
Exchange.OKX
Contributions are welcome! If you'd like to contribute to DeFinance, please follow these steps:
- Fork the repository.
- Create a new branch for your feature or bugfix.
- Make your changes.
- Submit a pull request.
DeFinance is released under the MIT License. See the LICENSE file for more details.
For any questions or inquiries, please contact [email protected].