python library to get MCX India data
Project description
mcxlib
mcxlib is a Python library for fetching publicly available market data from the MCX India website and returning it as pandas DataFrames.
It provides a lightweight wrapper around common MCX endpoints so you can pull market snapshots, derivatives data, and historical reports directly into your Python workflows.
What It Provides
- Live market data such as market watch, heat map, top gainers, and top losers
- Derivatives data such as option chain, put-call ratio, and most active contracts
- Historical reports such as bhav copy, date-wise historical data, and trading statistics
- MCX index and participant-level datasets such as iCOMDEX indices and PRO/CLI details
Installation
Install from PyPI:
pip install mcxlib
Upgrade an existing installation:
pip install --upgrade mcxlib
If you are working from source:
pip install -r requirements.txt
pip install -e .
Dependencies
The project relies mainly on:
pandasrequestsxlrd
Some MCX datasets are published as Excel files, so spreadsheet-reading support is required for part of the API.
Quick Start
import mcxlib
market_watch = mcxlib.get_market_watch()
print(market_watch.head())
bhav_copy = mcxlib.get_bhav_copy(
trade_date="20231102",
instrument="ALL",
)
option_chain = mcxlib.get_option_chain(
commodity="CRUDEOIL",
expiry="15NOV2023",
)
historical_data = mcxlib.get_historical_data(
start_date="20230101",
end_date="20231103",
)
Public API
All exported functions return a pandas.DataFrame.
Live Market Data
get_market_watch()get_heat_map()get_top_gainers()get_top_losers()get_most_active_contracts(instrument="ALL")get_most_active_puts_calls(option_type="PE", product="ALL", instrument="OPTFUT")
Options and Sentiment Data
get_recent_expires(commodity="ALL")get_option_chain(commodity="CRUDEOIL", expiry="15NOV2023")get_put_call_ratio(ratio_type="expiry_wise")
Historical and Report Data
get_bhav_copy(trade_date="YYYYMMDD", instrument="ALL")get_historical_date_wise_data(start_date="YYYYMMDD", end_date="YYYYMMDD")get_historical_data(start_date="YYYYMMDD", end_date="YYYYMMDD")get_category_wise_turnover(year=2023, month_number=9)get_category_wise_oi(year=2023, month_number=9)get_trading_statistics(year=2023, month_number=9)get_ccl_delivery(year=2023, month_number=9)
Index and Participant Data
get_mcx_icomdex_indices()get_pro_cli_details(trade_month="YYYYMM")
Parameter Notes
- Dates for
get_bhav_copy()andget_historical_data()useYYYYMMDD get_pro_cli_details()uses month formatYYYYMMget_option_chain()expiry usesDDMMMYYYY, for example15NOV2023- Historical date-wise queries are limited by MCX to a maximum range of 365 days
- Valid parameter values depend on what MCX currently exposes for each endpoint
Example Use Cases
Get the latest market watch data:
import mcxlib
df = mcxlib.get_market_watch()
print(df.columns)
print(df.head())
Fetch historical data for analysis:
import mcxlib
df = mcxlib.get_historical_data(
start_date="20230101",
end_date="20230331",
)
print(df.head())
Fetch option chain data for a commodity:
import mcxlib
df = mcxlib.get_option_chain(
commodity="CRUDEOIL",
expiry="15NOV2023",
)
print(df.head())
Error Handling
Most functions raise ValueError when:
- Parameters are invalid
- MCX does not return data for the request
- The upstream MCX endpoint format changes
If you receive an error, first verify the parameter format and whether the requested dataset is currently available on the MCX website.
Limitations
- This library depends on public MCX endpoints and report files remaining available
- Changes on the MCX website can break one or more functions without a package release
- Live data availability depends on MCX publishing current values at request time
Contributing
Contributions are welcome. If you want to help:
- Open an issue: https://github.com/RuchiTanmay/mcxlib/issues
- Submit a pull request with a focused fix or enhancement
- Share examples or documentation improvements to help other users get started
License
This project is licensed under the MIT License. See LICENSE for details.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mcxlib-0.2.tar.gz.
File metadata
- Download URL: mcxlib-0.2.tar.gz
- Upload date:
- Size: 13.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b5a0a55c7e14914d8c231c202c1bdfdc99153a9a034d1c6d3bef2366a1d9932e
|
|
| MD5 |
e16c829585dccb1bb789f5f928fc444d
|
|
| BLAKE2b-256 |
8da7f7cd51516323404da73c1314da9d90d1e3ea9e3841a434523b2836bb9a0d
|
File details
Details for the file mcxlib-0.2-py3-none-any.whl.
File metadata
- Download URL: mcxlib-0.2-py3-none-any.whl
- Upload date:
- Size: 12.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4dd0b5439be7dcf7354a2aff2d63d8d4be75578435bd18abf6051908ee854865
|
|
| MD5 |
be6c4bc00f80441b754c694cf35e1d29
|
|
| BLAKE2b-256 |
6c21501241779d0a2e52d80157a21052903cf33155210ab0c86e1c8ec36b905a
|