Skip to main content

Wrapper for financial database APIs

Project description

HongXiongMao Refuel

Toolbox for importing data from various financial sources; for a personal project so if you are here by accident I highly advise you look elsewhere.

Usage

There are no plans to go into any material depth here, so these are just notes to job my own memory.

Snowflake

Snowflake objects here specifically related to the snowflake-connector so connecting to a database. There are three main functions. rsa_token_stuff which returns pkb given a password string and private_key_file.p8 snowflake_connect which returns a snowflake-python-connector connection, snowflake_sql_engine returns an SQL Alchemy engine object. Not being a database pro, both seem to work but I favour the engine.

Both functions require the same inputs:

def snowflake_sql_engine(
    user_details: dict,                     # dictionary of required inputs
    method='rsa',                           # can be 'rsa' or 'user' 
    password: None | str = None,            # password if using rsa
    private_key_file: None | str = None     # file location of .p8 file if using RSA
    ):

To help there are also templates for the user_details:

SNOWFLAKE_RSA_USER_DETAILS_TEMPLATE = dict(
    user="USERNAME",
    password="",
    account="xx123455",
    region="eu-west-1",
    warehouse="LAB_SOMETHING_WH",
    database="LAB_SOMETHING",
    # schema="",)

As well as some helper functions check_compatibility tests a df vs. a snowflake table for compatability (could be a bit buggy) sql_append_with_drop_duplicates does as it says on the tin

Installation

Bloomberg API

To make Bloomberg calls, the blpapi package must be installed; we then extend the excellent xbbg package. Unfortunately, installing of blpapi can be a pain in the backside. I can't get pyproject.toml to correctly install blpapi as a dependency.

Using pip instruction from the Bloomberg website

python -m pip install --index-url=https://bcms.bloomberg.com/pip/simple blpapi

Poetry requires 2 steps

  1. Set up Bloomberg as a source,
  2. installing blpapi
poetry source add --priority=supplemental bloomberg https://bcms.bloomberg.com/pip/simple/
poetry add --source bloomberg blpapi

Snowflake SQL

In order to get snowflake connectors working we've had to install several additional packages. Snowflake is very picky about which versions of pyarrow etc... are installed and requires old versions.

snowflake-connector-python = "^3.2.0"
snowflake-sqlalchemy = "^1.5.0"
pyarrow = ">=10.0.1, <10.1.0"
cryptography = "^41.0.5"

Publishing to PyPi

I'm no pro at deploying packages to PyPi, so these are my notes for deployment of a poetry package. For reference, I followed this tutorial

Key points:

  • (PyPi account is required)[https://pypi.org/manage/account/#account-emails]
  • (Configure Poetry)[https://python-poetry.org/docs/repositories/#configuring-credentials]
  • poetry build
  • poetry publish
# configure API key
poetry config pypi-token.pypi <pypi-reallyREALLYllongKEY...>

# The build bit
(base) (hxm-refuel-py3.10) PS C:\Users\XXX\Documents\GitHub\hxm-refuel> poetry build

Building hxm-refuel (0.1.0)
  - Building sdist
  - Built hxm_refuel-0.1.0.tar.gz
  - Building wheel
  - Built hxm_refuel-0.1.0-py3-none-any.whl

# publishing bit
(base) (hxm-refuel-py3.10) PS C:\Users\T333208\Documents\GitHub\hxm-refuel> poetry publish

Publishing hxm-refuel (0.1.0) to PyPI
 - Uploading hxm_refuel-0.1.0-py3-none-any.whl 0%
 - Uploading hxm_refuel-0.1.0-py3-none-any.whl 85%
 - Uploading hxm_refuel-0.1.0-py3-none-any.whl 100%
 - Uploading hxm_refuel-0.1.0.tar.gz 0%
 - Uploading hxm_refuel-0.1.0.tar.gz 100%

Project details


Download files

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

Source Distribution

hxm_refuel-0.2.4.tar.gz (16.6 kB view details)

Uploaded Source

Built Distribution

hxm_refuel-0.2.4-py3-none-any.whl (19.4 kB view details)

Uploaded Python 3

File details

Details for the file hxm_refuel-0.2.4.tar.gz.

File metadata

  • Download URL: hxm_refuel-0.2.4.tar.gz
  • Upload date:
  • Size: 16.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.0 CPython/3.9.7 Windows/10

File hashes

Hashes for hxm_refuel-0.2.4.tar.gz
Algorithm Hash digest
SHA256 d0f9aacf3e7094006652fc92e844d55032de3bcfa99fc4d0adf804783aa0940d
MD5 487d0cd44f6fb4d05d9de018fa6c1e0f
BLAKE2b-256 3940b3d1dd57d971c03561083c6ebda1d6a83ccd5ea8c0de92819960beefc540

See more details on using hashes here.

Provenance

File details

Details for the file hxm_refuel-0.2.4-py3-none-any.whl.

File metadata

  • Download URL: hxm_refuel-0.2.4-py3-none-any.whl
  • Upload date:
  • Size: 19.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.0 CPython/3.9.7 Windows/10

File hashes

Hashes for hxm_refuel-0.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 e19ef9cb5a8f74e963e26b063b3def0f60e9b46df9a69c167062b81af1ad76ae
MD5 b9323e82919f9ce16694a8d8e6b8a9ea
BLAKE2b-256 d2e45451eaf9af5986584d36a3e794b22058704d236c461f02af39dd7e8228ec

See more details on using hashes here.

Provenance

Supported by

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