Skip to main content

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

  1. install requests by pip install requests
  2. choose a DataFrame library, pandas or polars, and install it by pip install pandas or pip install polars
  3. create a MsdClient instance by pymsd.create_msd_pandas or pymsd.create_msd_polars with the url of msd server
  4. use the MsdClient.load method 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

pymsd-0.1.11-cp310-abi3-win_amd64.whl (910.9 kB view details)

Uploaded CPython 3.10+Windows x86-64

pymsd-0.1.11-cp310-abi3-manylinux_2_34_x86_64.whl (1.2 MB view details)

Uploaded CPython 3.10+manylinux: glibc 2.34+ x86-64

pymsd-0.1.11-cp310-abi3-macosx_11_0_arm64.whl (401.7 kB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

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

Hashes for pymsd-0.1.11-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 9085a7d56853a8863e7074b2853fa1256c1079bccf232b1c0e5db6134d82e403
MD5 4612992008aba1583d799bf7661e596c
BLAKE2b-256 dfb35e7f9cbcc4afb060ec72ccca1f882e7145a0fe33abc03b0c0de41091c71e

See more details on using hashes here.

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

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pymsd-0.1.11-cp310-abi3-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for pymsd-0.1.11-cp310-abi3-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 60389cd2b58e393878e5463021437b35ac44f16d499624b0a60dca13a95d8fcc
MD5 f78b48ce09245287f34b515997ff855e
BLAKE2b-256 a4bc53ec2cbe3923ed3519c0276f278ad7a040c28fb6551fd0970dc9d872a698

See more details on using hashes here.

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

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pymsd-0.1.11-cp310-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for pymsd-0.1.11-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 4a8dc62afcac554b302179763f1b243f8f2193e65729c7d237694221c47122e1
MD5 81f5e23073d33c627d21a2abe594e35a
BLAKE2b-256 6c4b28154bd48b0f914e6236c2a1576dbf46ef42a2faa0bdeba291e6e4edb8f6

See more details on using hashes here.

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

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page