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.12-cp312-abi3-win_amd64.whl (910.3 kB view details)

Uploaded CPython 3.12+Windows x86-64

pymsd-0.1.12-cp312-abi3-manylinux_2_34_x86_64.whl (1.2 MB view details)

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

pymsd-0.1.12-cp312-abi3-macosx_11_0_arm64.whl (387.8 kB view details)

Uploaded CPython 3.12+macOS 11.0+ ARM64

File details

Details for the file pymsd-0.1.12-cp312-abi3-win_amd64.whl.

File metadata

  • Download URL: pymsd-0.1.12-cp312-abi3-win_amd64.whl
  • Upload date:
  • Size: 910.3 kB
  • Tags: CPython 3.12+, Windows x86-64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pymsd-0.1.12-cp312-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 99d16ac6e4f56347b8b54d4fbe73af1627b3ab38567895b9450512507e96c338
MD5 020afccc3730314c561500905d577e84
BLAKE2b-256 d894e7591d92adfa9d861e667591eab9326aa21df7366b7e187e007008d1ea4e

See more details on using hashes here.

Provenance

The following attestation bundles were made for pymsd-0.1.12-cp312-abi3-win_amd64.whl:

Publisher: build.yml on msd-rs/msd

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.12-cp312-abi3-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for pymsd-0.1.12-cp312-abi3-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 2c810a305bbe65bb880c66c37344665c7184e3f3390a1ab1455e6edcd3b88849
MD5 35a3acc53c5d234bd59c5de606772754
BLAKE2b-256 6bedb4e2f41b786b44b3fb3abe21f2ec4152040911368074e7cebce0be177143

See more details on using hashes here.

Provenance

The following attestation bundles were made for pymsd-0.1.12-cp312-abi3-manylinux_2_34_x86_64.whl:

Publisher: build.yml on msd-rs/msd

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.12-cp312-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for pymsd-0.1.12-cp312-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 9d08d424e84ba9fbb1083438b431934d98983632b4fb3a125b976660e7e1fe3f
MD5 0c814110087484ed05700625a807a4fb
BLAKE2b-256 02b0bdce84e7ac84eadb472a1d4574f2c26dc08676ea94a1c8f1158b8f4083c7

See more details on using hashes here.

Provenance

The following attestation bundles were made for pymsd-0.1.12-cp312-abi3-macosx_11_0_arm64.whl:

Publisher: build.yml on msd-rs/msd

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