Skip to main content

Async Python client for Korean exchange (KRX) stocks, futures, and options via KIS

Project description

kxt

PyPI Python License: MIT

kxt is an async Python SDK for Korea Exchange (KRX) equities, futures, and options, backed by the Korea Investment & Securities (KIS) OpenAPI. Documentation is written in Korean and published at https://pumpkinredbean.github.io/kxt/.


kxt는 한국거래소(KRX) 주식·선물·옵션을 비동기 파이썬으로 다루기 위한 SDK입니다. 현재는 KIS(한국투자증권) OpenAPI 어댑터 하나를 제공하며, 브로커 중립 DTO 계층 위에 얇게 얹혀 있습니다.

Audience

  • 파이썬으로 KRX 데이터를 수집하거나 자동매매 코드를 작성하는 개발자
  • ccxt 계열의 브로커 중립 인터페이스를 한국 시장에서 찾는 사용자
  • 라이브러리 우선(runtime-free) SDK를 선호하는 사용자

Key features

  • 비동기 전용async/await 기반, 이벤트 루프 친화적
  • 브로커 중립 DTOInstrumentRef, Bar, OrderBookSnapshot 등 정규화된 응답 타입 (입력은 종목 코드 문자열)
  • 시세·주문·스트림get_bars, get_quote, submit_order, stream_trades 등 flat 메서드
  • 얇은 CLI — 동일한 코드 경로를 kxt bars, kxt quote 같은 명령으로 호출

Import policy

  • from kxt import ...KISClient, 응답·이벤트 DTO, enum, 에러 등 사용자가 읽는 타입.
  • from kxt.requests import ...BarsRequest, SubmitOrderRequest, *Cursor, *Subscription, OrderInstruction, OrderAmendment, ProviderRef 같은 power-user 입력 DTO. 일반 호출은 primitive(symbol 문자열, kwargs)만으로 충분합니다.
  • from kxt.models import ... — 모든 DTO를 통째로 introspection할 때.

Install

pip install --pre kxt

현재 알파 릴리스이므로 --pre 플래그가 필요합니다. 1.0 이후 해제됩니다.

Quick start

import asyncio
from datetime import date, timedelta

from kxt import KISClient


async def main() -> None:
    async with KISClient(
        app_key="<APP_KEY>",
        app_secret="<APP_SECRET>",
    ) as client:
        today = date.today()
        response = await client.get_bars(
            "005930",  # 삼성전자
            timeframe="day",
            start=today - timedelta(days=14),
            end=today,
        )
        for bar in response.bars[-5:]:
            print(bar.opened_at.date(), bar.close)


asyncio.run(main())

<APP_KEY> / <APP_SECRET>은 본인의 KIS OpenAPI 자격증명으로 대체하세요. SDK는 환경변수에 관여하지 않습니다. 환경변수 기반 흐름은 CLI에서만 사용합니다.

Documentation

전체 한국어 문서: https://pumpkinredbean.github.io/kxt/

로컬에서 빌드하려면:

uv sync --all-extras
uv run pytest
uv run mkdocs serve
uv build

Status

현재 0.1.0a1 (alpha) 입니다. 공개 API는 1.0 이전까지 예고 없이 변경될 수 있습니다. 실거래 전에 반드시 소량으로 검증하세요.

License

MIT. LICENSE 참조.

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

kxt-0.1.0a2.tar.gz (65.0 kB view details)

Uploaded Source

Built Distribution

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

kxt-0.1.0a2-py3-none-any.whl (69.0 kB view details)

Uploaded Python 3

File details

Details for the file kxt-0.1.0a2.tar.gz.

File metadata

  • Download URL: kxt-0.1.0a2.tar.gz
  • Upload date:
  • Size: 65.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for kxt-0.1.0a2.tar.gz
Algorithm Hash digest
SHA256 6374b1e89ac3948154e391b9c0ce698069473ba738904d590aabfbca087c7d12
MD5 9d8aace6764e5b931c13cbe939775c0c
BLAKE2b-256 5da2415e5da36d9814bedcd1a3db2d63fd9dc0817bf197656a4e0a346a1e9e18

See more details on using hashes here.

Provenance

The following attestation bundles were made for kxt-0.1.0a2.tar.gz:

Publisher: publish.yml on pumpkinredbean/kxt

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

File details

Details for the file kxt-0.1.0a2-py3-none-any.whl.

File metadata

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

File hashes

Hashes for kxt-0.1.0a2-py3-none-any.whl
Algorithm Hash digest
SHA256 60253370dae9818af03d6ff73c605a894a75518f4c105fd5ae8c5fac997de45f
MD5 166b8b5bf7241a35b5210199a9aa0228
BLAKE2b-256 1dc8eaa1d430e0e168451a9f3da93a2d2c66050c2a3e56c589a8c082e607577e

See more details on using hashes here.

Provenance

The following attestation bundles were made for kxt-0.1.0a2-py3-none-any.whl:

Publisher: publish.yml on pumpkinredbean/kxt

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