Python binding for msd
Project description
Introduction
This is the Python binding for msd. msd is a high-performance financial time series database.
For high level usage, it provides MsdClient class, which uses requests and a DataFrame (pandas or polars) as the data format. You should install requests, pandas or polars manually.
High level API return DataFrame (pandas or polars) as the data format.
Installation
pip install pymsd
High Level Usage
- install
requestsbypip install requests - choose a DataFrame library,
pandasorpolars, and install it bypip install pandasorpip install polars - create a
MsdClientinstance bypymsd.create_msd_pandasorpymsd.create_msd_polarswith the url of msd server - use the
MsdClient.loadmethod to query data from msd
Low Level Usage
The transport layer is based on HTTP, and the data format can be JSON or Binary. The Binary format is more efficient and recommended for non-browser clients, binary format is parsed by pymsd._msd native library.
Because of the HTTP request library is very common, this package does not provide a client, instead it provides parse_reader and parse_reader_async functions to parse the HTTP response. With these functions, you can use any HTTP request library to query data from msd. For example, you can use requests for synchronous requests, and aiohttp for asynchronous requests.
It also provides pymsd.query and pymsd.query_async functions to query data from msd, which just demonstrate how to use pymsd.parse_reader and pymsd.parse_reader_async. When your want use these functions, your should install requests or aiohttp manually.
Performance
The performance of parse_reader and parse_reader_async is just same as the Rust based client, with about 1~2% overhead. For a test node, it can query about 6M rows of 1800 different symbols in about 1 second. The following table is the result of pytest .
RESULT_OBJECTS = 1789
RESULT_ROWS = 6245835
SQL_TO_TEST = "select * from kline where obj='SH60*'"
| Name (time in ms) | Min | Max | Mean | StdDev | Median | IQR | Outliers | OPS | Rounds | Iterations |
|---|---|---|---|---|---|---|---|---|---|---|
| test_query_many_ndarray | 972.8022 (1.0) | 978.1467 (1.0) | 976.1578 (1.0) | 2.1991 (1.0) | 975.8558 (1.0) | 3.0612 (1.0) | 1;0 | 1.0244 (1.0) | 5 | 1 |
| test_query_many_dataframe | 972.8057 (1.00) | 987.1984 (1.01) | 980.0452 (1.00) | 6.8454 (3.11) | 980.4594 (1.00) | 13.2980 (4.34) | 2;0 | 1.0204 (1.00) | 5 | 1 |
| test_query_many_polars | 973.1088 (1.00) | 995.1073 (1.02) | 982.3909 (1.01) | 9.5757 (4.35) | 979.7399 (1.00) | 16.7033 (5.46) | 1;0 | 1.0179 (0.99) | 5 | 1 |
| test_query_concat_polars | 991.4861 (1.02) | 999.8344 (1.02) | 994.1573 (1.02) | 3.3793 (1.54) | 993.7752 (1.02) | 3.8383 (1.25) | 1;0 | 1.0059 (0.98) | 5 | 1 |
| test_query_concat_pandas | 1,161.1306 (1.19) | 1,186.2676 (1.21) | 1,172.4941 (1.20) | 11.3836 (5.18) | 1,167.3264 (1.20) | 20.0729 (6.56) | 1;0 | 0.8529 (0.83) | 5 | 1 |
see the test_query.py for more 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 Distributions
Built Distributions
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 pymsd-0.1.11-cp310-abi3-win_amd64.whl.
File metadata
- Download URL: pymsd-0.1.11-cp310-abi3-win_amd64.whl
- Upload date:
- Size: 910.9 kB
- Tags: CPython 3.10+, Windows x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9085a7d56853a8863e7074b2853fa1256c1079bccf232b1c0e5db6134d82e403
|
|
| MD5 |
4612992008aba1583d799bf7661e596c
|
|
| BLAKE2b-256 |
dfb35e7f9cbcc4afb060ec72ccca1f882e7145a0fe33abc03b0c0de41091c71e
|
Provenance
The following attestation bundles were made for pymsd-0.1.11-cp310-abi3-win_amd64.whl:
Publisher:
build.yml on msd-rs/msd-app
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pymsd-0.1.11-cp310-abi3-win_amd64.whl -
Subject digest:
9085a7d56853a8863e7074b2853fa1256c1079bccf232b1c0e5db6134d82e403 - Sigstore transparency entry: 804568418
- Sigstore integration time:
-
Permalink:
msd-rs/msd-app@1c692af70efa74dc03a319c11bd683b6a628da58 -
Branch / Tag:
refs/tags/v0.1.11 - Owner: https://github.com/msd-rs
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build.yml@1c692af70efa74dc03a319c11bd683b6a628da58 -
Trigger Event:
push
-
Statement type:
File details
Details for the file pymsd-0.1.11-cp310-abi3-manylinux_2_34_x86_64.whl.
File metadata
- Download URL: pymsd-0.1.11-cp310-abi3-manylinux_2_34_x86_64.whl
- Upload date:
- Size: 1.2 MB
- Tags: CPython 3.10+, manylinux: glibc 2.34+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
60389cd2b58e393878e5463021437b35ac44f16d499624b0a60dca13a95d8fcc
|
|
| MD5 |
f78b48ce09245287f34b515997ff855e
|
|
| BLAKE2b-256 |
a4bc53ec2cbe3923ed3519c0276f278ad7a040c28fb6551fd0970dc9d872a698
|
Provenance
The following attestation bundles were made for pymsd-0.1.11-cp310-abi3-manylinux_2_34_x86_64.whl:
Publisher:
build.yml on msd-rs/msd-app
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pymsd-0.1.11-cp310-abi3-manylinux_2_34_x86_64.whl -
Subject digest:
60389cd2b58e393878e5463021437b35ac44f16d499624b0a60dca13a95d8fcc - Sigstore transparency entry: 804568415
- Sigstore integration time:
-
Permalink:
msd-rs/msd-app@1c692af70efa74dc03a319c11bd683b6a628da58 -
Branch / Tag:
refs/tags/v0.1.11 - Owner: https://github.com/msd-rs
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build.yml@1c692af70efa74dc03a319c11bd683b6a628da58 -
Trigger Event:
push
-
Statement type:
File details
Details for the file pymsd-0.1.11-cp310-abi3-macosx_11_0_arm64.whl.
File metadata
- Download URL: pymsd-0.1.11-cp310-abi3-macosx_11_0_arm64.whl
- Upload date:
- Size: 401.7 kB
- Tags: CPython 3.10+, macOS 11.0+ ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4a8dc62afcac554b302179763f1b243f8f2193e65729c7d237694221c47122e1
|
|
| MD5 |
81f5e23073d33c627d21a2abe594e35a
|
|
| BLAKE2b-256 |
6c4b28154bd48b0f914e6236c2a1576dbf46ef42a2faa0bdeba291e6e4edb8f6
|
Provenance
The following attestation bundles were made for pymsd-0.1.11-cp310-abi3-macosx_11_0_arm64.whl:
Publisher:
build.yml on msd-rs/msd-app
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pymsd-0.1.11-cp310-abi3-macosx_11_0_arm64.whl -
Subject digest:
4a8dc62afcac554b302179763f1b243f8f2193e65729c7d237694221c47122e1 - Sigstore transparency entry: 804568421
- Sigstore integration time:
-
Permalink:
msd-rs/msd-app@1c692af70efa74dc03a319c11bd683b6a628da58 -
Branch / Tag:
refs/tags/v0.1.11 - Owner: https://github.com/msd-rs
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build.yml@1c692af70efa74dc03a319c11bd683b6a628da58 -
Trigger Event:
push
-
Statement type: