Skip to main content

Korea Investment & Securities API Utils

Project description

KIS Utils

한국투자증권 API를 파이썬에서 쉽고 간편하게 사용할 수 있도록 도와주는 유틸리티 모듈로 CLI 인터페이스를 제공합니다. 접근 토큰 관리, 시세 조회, 잔고 확인 및 주문 기능을 간결한 인터페이스로 제공합니다.

비교적 간편한 유틸리티 라이브러리로 사용하거나 CLI로 사용이 가능합니다 /

🚀 시작하기

1. .env 파일 설정

한국투자증권 API Key(App Key, App Secret)는 KIS Developers에서 신청하여 발급받을 수 있습니다. 한국투자증권 계좌를 보유하고 있어야 하며, 모의투자 또는 실전투자 앱을 통해 신청하여 1년간 무료로 사용할 수 있습니다.

프로젝트 루트 디렉토리에 .env.example 파일을 복사하여 .env 파일을 생성하고 다음과 같이 환경 변수를 설정합니다.

# 실행 환경 ("실전투자" 또는 "모의투자")
KIS_ENVIRONMENT="모의투자"

# 실전투자 정보
KIS_APP_KEY="YOUR_PROD_APP_KEY"
KIS_APP_SECRET="YOUR_PROD_APP_SECRET"
KIS_ACCOUNT="YOUR_ACCOUNT_NUMBER"
KIS_ACCOUNT_PROD="01"

# 모의투자 정보 (KIS_ENVIRONMENT="모의투자"인 경우 필수)
KIS_APP_KEY_VTS="YOUR_VTS_APP_KEY"
KIS_APP_SECRET_VTS="YOUR_VTS_APP_SECRET"
KIS_ACCOUNT_VTS="YOUR_VTS_ACCOUNT_NUMBER"
KIS_ACCOUNT_PROD_VTS="01"

CLI 사용법 (간편 사용)

설치

uv tool install --upgrade kis_utils

활용법

# 현재가 조회 (기본 JSON 출력)
kis_utils price 005930

# 사람이 읽기 좋은 포맷으로 조회
kis_utils price 005930 --pretty

# 계좌 잔고 확인
kis_utils balance --pretty

# 주식 주문 (삼성전자 1주 시장가 매수)
kis_utils order 005930 -t buy -q 1 -p 0

# 주식 주문 (삼성전자 1주 시장가 매수)
kis_utils order 005930 --type buy --qty 1 --price 0

# 주식 주문 (삼성전자 1주 지정가 매수)
kis_utils order 005930 -t buy -q 1 -p 260000

# 주식 주문 (삼성전자 10주 지정가 매도)
kis_utils order 005930 -t sell -q 10 -p 280000

# 기간별 시세 (삼성전자 일자별 시세 조회)
kis_utils daily 005930 --pretty

# 매수가능 수량 조회 (삼성전자, 지정가 260000원 기준)
kis_utils buyable -p 260000 005930 --pretty

# 매수가능 수량 조회 (삼성전자, 시장가 기준)
kis_utils buyable -p 0 005930 --pretty

# 최근 7일간 주문 및 체결 내역 조회
kis_utils history --pretty

주요 명령어

  • token: 접근 토큰 신규 발급
  • price <종목코드>: 현재가 정보 조회
  • daily <종목코드>: 일/주/월 봉 데이터 조회
  • balance: 계좌 잔고 및 보유 종목 조회
  • history: 주문 및 체결 내역 조회 (전체)
  • unfilled: 미체결 내역 조회
  • order: 주식 주문 (매수/매도), 가격을 0으로 지정하면 시장가 주문으로 처리됨
  • buyable <종목코드>: 매수 가능 수량 조회

모든 명령어 뒤에 --pretty를 붙이면 한글 라벨이 포함된 가독성 좋은 화면을 볼 수 있습니다.

API 사용법 (개발자용)

설치

git clone https://github.com/FinanceData/kis_utils.git

API 사용

1. 접근 토큰 발급

import kis_utils as kis

# 토큰 발급 (자동으로 파일에 저장 및 갱신됨)
access_token = kis.token()

2. 주식 시세 및 데이터 조회

현재가 조회

# 삼성전자 현재가 조회
df = kis.price("005930")
if not price_df.empty:
    current_price = int(price_df['stck_prpr'].iloc[0])
    print(f"현재가: {current_price:,}원")

일봉 데이터 조회

from datetime import datetime, timedelta

today = datetime.now()
start_date = (today - timedelta(days=30)).strftime("%Y%m%d")
end_date = today.strftime("%Y%m%d")

# 최근 30일 일봉 데이터
daily_data = kis.daily("005930")

# 주봉 데이터
weekly_data = kis.daily("005930", period="W")

3. 계좌 및 주문 관리

계좌 잔고 조회

balance = kis.balance()

# 예수금 확인
deposit = int(balance['output2'][0]['dnca_tot_amt'])

# 보유 종목 확인
for stock in balance['output1']:
    print(f"종목명: {stock['prdt_name']}, 보유수량: {stock['hldg_qty']}")

주문 내역 조회

# 최근 7일간 주문 내역 조회
history = kis.order_history(start_date, end_date)

주식 주문

# 삼성전자 1주 시장가 매수
result = kis.buy(
    stock_code="005930",
    quantity=1,
    price=0,               # 시장가인 경우 0
    order_division="03"    # 01: 지정가, 03: 시장가
)

# 삼성전자 1주 지정가 매도
result = kis.sell(
    stock_code="005930",
    quantity=1,
    price=70000,
    order_division="01"
)

📝 참고 사항

  • 토큰 자동 관리: 발급된 토큰은 .access_token 파일에 자동 저장되며, 만료 전 호출 시 기존 토큰을 재사용하거나 필요시 자동 갱신합니다.
  • 오류 처리: API 호출 실패 시 관련 에러 메시지를 출력하며, 네트워크 상태나 앱 키 설정을 확인해야 합니다.
  • 주문 주의: place_order 함수는 실제 거래를 발생시키므로, 충분한 테스트 후에 실전 투자에 사용하시기 바랍니다.

📄 라이선스

이 프로젝트는 MIT 라이선스 하에 배포됩니다.


2026 FinanceData.KR

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

kis_utils-0.1.5.tar.gz (28.7 kB view details)

Uploaded Source

Built Distribution

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

kis_utils-0.1.5-py3-none-any.whl (10.1 kB view details)

Uploaded Python 3

File details

Details for the file kis_utils-0.1.5.tar.gz.

File metadata

  • Download URL: kis_utils-0.1.5.tar.gz
  • Upload date:
  • Size: 28.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.2 {"installer":{"name":"uv","version":"0.11.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for kis_utils-0.1.5.tar.gz
Algorithm Hash digest
SHA256 daeaa6fd9c2599520dcadcddac148292597260d4f690b5ae820ad353698460ff
MD5 14394e6b2623d43353bb102df5e450ba
BLAKE2b-256 e40369cf33bd001e612423b5359304c0fdd0b4adb9e73f29e6f28d6171b1b512

See more details on using hashes here.

File details

Details for the file kis_utils-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: kis_utils-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 10.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.2 {"installer":{"name":"uv","version":"0.11.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for kis_utils-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 8425334234f9f1c59c147ecdc724d12def35d40b38689e8755dfe435b8c9044a
MD5 8282a564f081f2930f1cca72b4f0c7e3
BLAKE2b-256 f0094d5ae6249686db0668ec096d8e1995205a40dd89a0b2335685a12866c1aa

See more details on using hashes here.

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