/pykis

한국투자증권 신규 Open Trade API 를 쉽게 사용하기 위한 python 패키지

Primary LanguagePythonApache License 2.0Apache-2.0

pykis

  • pykis는 한국투자증권에서 제공하는 Open Trading API를 쉽게 사용하기 위한 비공식 python wrapper입니다.

  • 기존 eFriend expert (HTS 프로그램) 연동 방식 API 대비 다음과 같은 장점들이 있습니다.

    • Web API 방식 사용
    • 별도의 HTS 프로그램에 의존하지 않음
    • 사용 가능 환경(OS)에 제한이 없음
  • 기존 eFriend expert 연동 방식 API를 사용하는 python 패키지는 pjueon/eFriendPy를 참고하세요.

사용전 유의사항

License 관련

pykis는 Apache-2.0 license를 따릅니다.

  • Apache-2.0 license에서 규정하는 조건 안에서 자유롭게 수정/재배포/사용이 가능합니다. 자세한 사항은 LICENSE를 참고 바랍니다.
  • pykis의 동작에는 불완전한 부분이나 버그가 있을 수 있습니다. 또한 pykis의 API는 언제든 변경될 수 있습니다.
  • pykis의 제작자(pjueon)는 이 코드에 대해서 어떤 것도 보장하지 않습니다. 코드 사용중 생긴 어떠한 종류의 피해(ex> 버그, 사용자의 실수, 투자로 인한 손실 등)에 대해서도 책임지지 않습니다.

KIS Developers 서비스 신청

  • pykis를 사용하기 위해서는 한국투자증권 홈페이지에서 KIS Developers 서비스 신청을 통해 API key를 발급받아야 합니다.
  • KIS Developers 서비스 신청방법은 한국투자증권의 공식 wikidocs를 참고하세요.

기타

  • pykis는 개인 투자 용도로만 개발되었습니다.
  • pykis를 사용하기 위해서는 python 3.7 버전 이상이 필요합니다.
  • pykis는 아직 개발 단계입니다. 버그나 기능 요청 등의 feedback은 issue나 pull request를 통해 부탁드립니다.

패키지 설치

Github에서 직접 다운로드

pykis는 현재 개발 단계로 수정이 잦습니다. github repository를 clone하여 최신 버전을 사용하는 것을 추천합니다.

git clone https://github.com/pjueon/pykis.git
cd pykis
pip3 install -r requirements.txt

pip를 통해 설치

pip를 통해 가장 마지막으로 release된 버전을 설치할 수 있습니다.

pip3 install pykis

API 기본 사용법

패키지 import

import pykis

Api 객체 생성

실제 계좌를 사용하는 경우

# API 사용을 위한 API key정보 및 계좌 정보를 설정합니다. 
# 별도의 파일(json, yaml, xml, etc) 등에 내용을 저장하여 불러오는 것을 추천합니다. 
# key 정보는 절대 외부로 유출되지 않도록 주의하시고, 유출시 즉시 재발급 하시기 바랍니다.  

key_info = {		# KIS Developers 서비스 신청을 통해 발급받은 API key 정보
	"appkey": "[발급 받은 APP Key]",                  
	"appsecret": "[발급 받은 APP Secret]" 
}

account_info = {	# 사용할 계좌 정보
	"account_code": "[API를 신청한 종합 계좌번호(계좌번호 앞자리 8자리 숫자)]",   
	"product_code": "[계좌번호의 끝자리 2자리 숫자]"             # ex> "01", "22", etc
}

# API 객체 생성 
api = pykis.Api(key_info=key_info, account_info=account_info)

모의 계좌를 사용하는 경우

domain = pykis.DomainInfo(kind="virtual")


# API 객체 생성 
api = pykis.Api(key_info=key_info, domain_info=domain_info, account_info=account_info)

사용 계좌 변경

account_info = {    # 사용할 계좌 정보
	"account_code": "[API를 신청한 종합 계좌번호(계좌번호 앞자리 8자리 숫자)]",   
	"product_code": "[계좌번호의 끝자리 2자리 숫자]"             # ex> "01", "22", etc
}

api.set_account(account_info)

국내 주식 관련

거래 가능 현금 조회

cash = api.get_kr_buyable_cash()

국내 주식 현재가 조회

ticker = "005930"   # 삼성전자 종목코드
price = api.get_kr_current_price(ticker)

국내 주식 최근 가격 조회 (일/주/월 OHLCV)

# 최근 30 일/주/월 OHLCV 데이터를 DataFrame으로 반환
ticker = "005930"   # 삼성전자 종목코드
time_unit = "D"     # 기간 분류 코드 (D/day-일, W/week-주, M/month-월), 기본값 "D"
ohlcv = api.get_kr_ohlcv(ticker, time_unit)

국내 주식 하한가 조회

ticker = "005930"   # 삼성전자 종목코드
price = api.get_kr_min_price(ticker)

국내 주식 상한가 조회

ticker = "005930"   # 삼성전자 종목코드
price = api.get_kr_max_price(ticker)

국내 주식 잔고 조회

# DataFrame 형태로 국내 주식 잔고 반환 
stocks_kr = api.get_kr_stock_balance()

국내 주식 총 예수금 조회

deposit = api.get_kr_deposit()

국내 주식 매수 주문

ticker = "005930"   # 삼성전자 종목코드
price = 100000      # 매수 가격 예시. 가격이 0 이하인 경우 시장가로 매수
amount = 1          # 주문 수량

# 삼성전자 1주를 지정가로 매수 주문 
api.buy_kr_stock(ticker, amount, price=price)

국내 주식 매도 주문

ticker = "005930"   # 삼성전자 종목코드
price = 100000      # 매도 가격 예시. 가격이 0 이하인 경우 시장가로 매도
amount = 1          # 주문 수량

# 삼성전자 1주를 지정가로 매도 주문 
api.sell_kr_stock(ticker, amount, price=price)

정정/취소 가능한 국내 주식 주문 조회

# 정정/취소 가능한 국내 주식 주문을 DataFrame으로 반환
orders = api.get_kr_orders()

미체결 국내 주식 주문 취소

# order_number: 주문 번호. api.get_kr_orders 통해 확인 가능.
# amount: 취소할 주문 수량. 지정하지 않은 경우 잔량 전부 취소.
api.cancel_kr_order(order_number, amount)

모든 미체결 국내 주식 주문 취소

api.cancel_all_kr_orders()

국내 주식 주문 정정

# order_number: 주문 번호. api.get_kr_orders 통해 확인 가능.
# price: 정정할 1주당 가격.
# amount: 정정할 주문 수량. 지정하지 않은 경우 잔량 전부 정정.
api.revise_kr_order(order_number, price, amount)

해외 주식 관련

거래소 코드

홍콩 뉴욕 나스닥 아멕스 도쿄 상해 심천 호치민 하노이
거래소 코드 HKS NYS NAS AMS TSE SHS SZS HSX HNX

해외 주식 현재가 조회

# ticker: 종목코드
# market_code: 거래소 코드 (상기 표 참고)
ticker = "TSLA"			# 테슬라 종목코드
market_code: "NAS"		# 나스닥 거래소 코드

price = api.get_os_current_price(ticker, market_code)

해외 주식 잔고 조회

# DataFrame 형태로 해외 주식 잔고 반환 
stocks_os = api.get_os_stock_balance()

해외 주식 매수 주문

ticker = "TSLA"			# 테슬라 종목코드
market_code: "NAS"		# 나스닥 거래소 코드
price = # ... (해외 주식은 시장가를 지원하지 않음)

# 테슬라 1주 매수 주문 
api.buy_kr_stock(ticker, market_code, 1, price=price)

해외 주식 매도 주문

ticker = "TSLA"			# 테슬라 종목코드
market_code: "NAS"		# 나스닥 거래소 코드
price = # ... (해외 주식은 시장가를 지원하지 않음)

# 테슬라 1주 매도 주문 
api.sell_kr_stock(ticker, market_code, 1, price=price)

미체결 해외 주식 주문 조회

# 모든 미체결 해외 주식 주문들을 DataFrame으로 반환
orders = api.get_os_orders()

관련 참고 자료