Skip to main content

Python CLI for kFinance

Project description

kFinance

The kFinance Python library provides a simple interface for the LLM-ready API, streamlining API requests and response handling. It can be used on its own, with LLMs, or integrated into applications.

For a complete overview of the functions, usage, and features of the kFinance Python library, please refer to documentation here.

Any questions or suggestions can be sent to the kFinance Maintainers.

Setup

You can install kFinance on PyPI via

pip install kensho-kfinance

Getting started

To receive access, please email S&P Global Market Intelligence for information on free trials and pricing.

Once access is obtained, get started using the Authentication Guide and Usage Guide.

To get started, we provide some notebooks:

  • The LLM-ready API Basic Usage notebook demonstrates how fetch data with the kFinance client.
  • The tool_calling notebooks show how the kFinance library can be used for tool calling. We provide notebooks for OpenAI (GPT), Anthropic (Claude), and Google (Gemini). Each of these integrations comes in a langchain version, which uses langchain as a wrapper to simplify the integration, and as a lower level non-langchain version.

We also provide an interactive notebook that demonstrates some usage examples.

MCP (Model Context Protocol)

To run the kFinance MCP server use:

python -m kfinance.mcp

This function initializes and starts an MCP server that exposes the kFinance tools. The server supports multiple authentication methods and transport protocols to accommodate different deployment scenarios.

The server's full signature is as follows:

kfinance.mcp [--stdio|-s|--sse|--streamable-http] --refresh-token <refresh-token> --client-id <client-id> --private-key <private-key>

Authentication Methods (in order of precedence):

  1. Refresh Token: Uses an existing refresh token for authentication. The --refresh-token <refresh-token> argument must be provided.
  2. Key Pair: Uses client ID and private key for authentication. Both the --client-id <client-id> and --private-key <private-key> arguments must be provided.
  3. Browser: Falls back to browser-based authentication flow. This occurs if no auth arguments are provided.

Transport Layers:

  • --stdio / -s: Standard input/output transport (use with MCP Inspector)
  • --sse: Server-Sent Events transport (default)
  • --streamable-http: HTTP transport

Examples:

# Using stdio with MCP Inspector
npx @modelcontextprotocol/inspector python -m kfinance.mcp --stdio --refresh-token <token>

# Using SSE (default)
python -m kfinance.mcp --refresh-token <token>

# Using streamable-http
python -m kfinance.mcp --streamable-http --refresh-token <token>

Development

Working with Local Package Version

If you need to develop using a local version of the kFinance package in another project that uses poetry for package and dependency management, follow these steps:

  1. In your dependent project's pyproject.toml, replace the kFinance package version specification:

    # Replace this:
    # kensho-kfinance = "~2.0.1"
    # With this:
    kensho-kfinance = { path = "/absolute/path/to/kfinance", develop = true }
    

    The develop = true flag ensures that the package always matches your local version without requiring reinstallation after changes.

  2. Update your project's dependencies:

    poetry update    # Update poetry.lock with new changes
    poetry install   # Install dependencies with updated configuration
    

    If you encounter the error "your pyproject.toml file has significantly changed", run:

    poetry lock     # Sync the changes to poetry.lock
    

Versioning

The kFinance uses semantic versioning (major, minor, patch). To bump the version, add a new entry in CHANGELOG.md. This will generate a new version of the library as part of the release process.

License

Licensed under the Apache 2.0 License. Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

Copyright 2025-present Kensho Technologies, LLC. The present date is determined by the timestamp of the most recent commit in the repository.

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

kensho_kfinance-6.3.0.tar.gz (179.6 kB view details)

Uploaded Source

Built Distribution

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

kensho_kfinance-6.3.0-py3-none-any.whl (203.7 kB view details)

Uploaded Python 3

File details

Details for the file kensho_kfinance-6.3.0.tar.gz.

File metadata

  • Download URL: kensho_kfinance-6.3.0.tar.gz
  • Upload date:
  • Size: 179.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for kensho_kfinance-6.3.0.tar.gz
Algorithm Hash digest
SHA256 bde4f7ad8acf8754c5f152a51f97d92f942a46afe369b1ba0a5510c26da3cb68
MD5 9a262130793c1872692f7fdb8fa89461
BLAKE2b-256 ad6bc86fdd77155ca0887711a81e8b1f262112b427eceda59ac77dffb4db0ec3

See more details on using hashes here.

Provenance

The following attestation bundles were made for kensho_kfinance-6.3.0.tar.gz:

Publisher: python-publish.yml on kensho-technologies/kfinance

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

File details

Details for the file kensho_kfinance-6.3.0-py3-none-any.whl.

File metadata

  • Download URL: kensho_kfinance-6.3.0-py3-none-any.whl
  • Upload date:
  • Size: 203.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for kensho_kfinance-6.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 489ba43bd7ce17f5d70a611bdf17fa39d2a79d977cca9d21a6ab61fa1cc1890d
MD5 2eab463732488e2a34ed975e09086d14
BLAKE2b-256 a1863446caef13c7c355b434394acf7fa4cef050b824703ce83ea22617f0ff2b

See more details on using hashes here.

Provenance

The following attestation bundles were made for kensho_kfinance-6.3.0-py3-none-any.whl:

Publisher: python-publish.yml on kensho-technologies/kfinance

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