Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/devansh3712/cmc-py
Unofficial CoinMarketCap API and Python wrapper
https://github.com/devansh3712/cmc-py
fastapi python redis selenium
Last synced: 4 months ago
JSON representation
Unofficial CoinMarketCap API and Python wrapper
- Host: GitHub
- URL: https://github.com/devansh3712/cmc-py
- Owner: Devansh3712
- License: mit
- Created: 2022-02-14T06:48:31.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-03-15T12:18:06.000Z (almost 3 years ago)
- Last Synced: 2024-10-14T04:35:37.425Z (4 months ago)
- Topics: fastapi, python, redis, selenium
- Language: Python
- Homepage: https://devansh3712.github.io/cmc-py/
- Size: 828 KB
- Stars: 7
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# cmc-py
Unofficial [CoinMarketCap](https://coinmarketcap.com/) API and Python wrapper. `cmc-py` uses `Selenium` and `BeautifulSoup` to scrape the website and return desired data.[data:image/s3,"s3://crabby-images/a8e53/a8e530b41cd951191fa906ada58c955049fa33f0" alt="pytest"](https://github.com/Devansh3712/cmc-py/actions/workflows/test.yml) [data:image/s3,"s3://crabby-images/8194f/8194f8b0ab18a81140f39037d7ad2fd037ae6a7a" alt="codecov"](https://github.com/Devansh3712/cmc-py/actions/workflows/codecov-coverage.yml) [data:image/s3,"s3://crabby-images/54a06/54a069bc5864ec407d08a7d3d3f9f2f63f66efd4" alt="PyPI"](https://github.com/Devansh3712/cmc-py/actions/workflows/python-publish.yml) [data:image/s3,"s3://crabby-images/014fe/014fe7a79c46f9913ad67d3864b80d8316bb6122" alt="Docker Image CI"](https://github.com/Devansh3712/cmc-py/actions/workflows/docker-image.yml) [data:image/s3,"s3://crabby-images/8eb85/8eb85d0061c742de26adbd21cd984fc2a84d521c" alt="Docker Build and Push Image"](https://github.com/Devansh3712/cmc-py/actions/workflows/docker-publish.yml) [data:image/s3,"s3://crabby-images/98647/986475842f2907062b79c4bb27fdd075d638e5b9" alt="Code style: black"](https://github.com/psf/black) [data:image/s3,"s3://crabby-images/f75d5/f75d5a25ac9d105d16006bf985691018d1988ffa" alt="codecov"](https://codecov.io/gh/Devansh3712/cmc-py)
### Installation
- Using `setup.py`
```shell
python setup.py install
```- Using `Python Package Index`
```shell
pip install cmc-py-wrapper
```- Using `poetry`
```
poetry install
```### Wrapper
`cmc-py` library can be used to fetch data for the following:
- `CryptoCurrencies`
```python
from cmc import Trending, format_datatop_30_trending = Trending().get_data
print(format_data(top_30_trending))
```- `Exchanges`
```python
from cmc import Spot, format_dataspot_exchanges = Spot().get_data
print(format_data(spot_exchanges))
```- `Non Fungible Tokens (NFTs)`
```python
from cmc import UpcomingSale, format_dataupcoming_nft_sales = UpcomingSale(pages=[1, 2]).get_data
print(format_data(upcoming_nft_sales))
```### API
An API is also built using the `cmc-py` modules using `FastAPI` and `Redis`. Redis configurations can be set using the `config.yml` file, and it is used to cache the scraped data fetched through `cmc-py`. `Redis` server should be running in the background in order to cache API calls. An instance of the API is hosted on [Heroku](https://cmc-api.herokuapp.com/docs#/).- Running the API locally
```shell
uvicorn api.main:app
```- Building the API using `Dockerfile`
```shell
docker build -t cmc .
docker compose up -d
```- Running the API using [`Docker Image`](https://hub.docker.com/r/devansh3712/cmc-api)
```shell
docker pull devansh3712/cmc-api
docker run devansh3712/cmc-api
```