A package to export bulk data from the CoinGecko API.
Project description
CoinGecko API Wrapper
This project provides a Python wrapper for the CoinGecko API, enabling users to fetch cryptocurrency data, process it into pandas DataFrames, and upload it to AWS S3 as Parquet files. The wrapper abstracts away the complexity of asynchronous API calls and provides an easy-to-use interface for interacting with the CoinGecko API.
Table of Contents
Installation
-
Clone the repository:
```bash git clone https://github.com/yourusername/coingecko-api-wrapper.git cd coingecko-api-wrapper ```
-
Set up a virtual environment:
```bash python3 -m venv venv source venv/bin/activate ```
-
Install the required dependencies:
```bash pip install -r requirements.txt ```
Class Structure
CoinGeckoAPI
The `CoinGeckoAPI` class is responsible for interacting directly with the CoinGecko API. It handles:
- Making asynchronous GET requests to the API.
- Managing rate limits using `AsyncLimiter`.
- Fetching data from paginated endpoints.
Methods:
- `fetch(endpoint: str, params: dict = None, retries: int = 3) -> dict`: Performs a GET request to the specified endpoint.
- `fetch_all_pages(endpoint: str, params: dict, max_pages: int) -> list`: Fetches all pages of data asynchronously.
CoinGeckoDataProcessor
The `CoinGeckoDataProcessor` class processes raw data fetched from the CoinGecko API. It handles:
- Merging timeseries data into a pandas DataFrame.
- Saving DataFrames to Parquet files.
Methods:
- `merge_timeseries_data(data: dict, coingecko_id: str) -> pd.DataFrame`: Cleans and merges timeseries data.
- `save_to_parquet(df: pd.DataFrame, file_path: str)`: Saves a DataFrame to a Parquet file.
CoinGecko
The `CoinGecko` class is the main interface for users. It abstracts away the complexities of asynchronous calls and provides simple, synchronous methods to fetch data, process it, and upload it to S3.
Methods:
- `get_categories() -> pd.DataFrame`: Fetches all categories from the CoinGecko API.
- `get_coins(coins: int, category: str = None) -> pd.DataFrame`: Fetches a list of assets based on market cap.
- `get_timeseries(coingecko_ids: list) -> pd.DataFrame`: Fetches and processes timeseries data.
- `export_data(coins: Union[int, List[str]], export_format: str = 'df') -> pd.DataFrame`: Fetches and exports data as a DataFrame or saves it as a Parquet file.
- `upload_to_s3(df: pd.DataFrame, aws_access_key_id: str, aws_secret_access_key: str, bucket_name: str, folder_name: str = None, file_name: str = None)`: Uploads a DataFrame to AWS S3 as a Parquet file.
Usage
Fetching Categories
```python from coingecko import CoinGecko
cg = CoinGecko(api_key="your-api-key")
Fetch and print the categories DataFrame
categories_df = cg.get_categories() print(categories_df) ```
Fetching Coins
```python from coingecko import CoinGecko
cg = CoinGecko(api_key="your-api-key")
Fetch top 100 coins by market cap
coins_df = cg.get_coins(100) print(coins_df) ```
Fetching Timeseries Data
```python from coingecko import CoinGecko
cg = CoinGecko(api_key="your-api-key")
Fetch timeseries data for a list of coin IDs
timeseries_df = cg.get_timeseries(['bitcoin', 'ethereum']) print(timeseries_df) ```
Exporting Data to Parquet
```python from coingecko import CoinGecko
cg = CoinGecko(api_key="your-api-key")
Export data to a Parquet file
cg.export_data(coins=100, export_format='parquet') ```
Uploading Data to S3
```python from coingecko import CoinGecko
cg = CoinGecko(api_key="your-api-key")
Fetch and upload coins data to S3
coins_df = cg.get_coins(100) cg.upload_to_s3( df=coins_df, aws_access_key_id="your-aws-access-key-id", aws_secret_access_key="your-aws-secret-access-key", bucket_name="your-s3-bucket-name", folder_name="your-folder-name", file_name="your-file-name.parquet" ) ```
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file coingecko_exporter-0.3.2.tar.gz
.
File metadata
- Download URL: coingecko_exporter-0.3.2.tar.gz
- Upload date:
- Size: 5.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 12ba13a32c33a4b615fd3b6a0d362af417d5a0af6bf3e26e0ccb622e4a9e00c5 |
|
MD5 | e3ea3f02ed19be1eeb2c3e1426827de6 |
|
BLAKE2b-256 | 1edf6899da46ef328873807cac3f2c44f0266e06a50413a8c64c6de637ee7df6 |
File details
Details for the file coingecko_exporter-0.3.2-py3-none-any.whl
.
File metadata
- Download URL: coingecko_exporter-0.3.2-py3-none-any.whl
- Upload date:
- Size: 5.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e5caf4e2dcfaa86730c1f208beaa30e983d50103965ba0976add3959499a24eb |
|
MD5 | 1aa996999ade584d49f0fabed2403d6a |
|
BLAKE2b-256 | a717178c8358d76d69f0e06446e8d12a01b8c321fe755e32c826b12d92ff1c7b |