본문 바로가기

반응형

[Toy Project] 자동매매

[Toy Project] 자동매매 프로그램 만들기 - 7. 매매 정보 엑셀에 기록하기 [목차] 1. 매매 함수 반환 값 분석 2. 매매 기록 엑셀에 자동 기록 3. 주기적으로 엑셀에 시가 기록 1. 매매 함수 반환 값 분석 매매 정보를 엑셀에 기록하기에 앞서, 매매를 했을 때 반환되는 결과가 어떤 형태인지 먼저 알아보자. 우선, 매매할 때 이용하는 함수는 buy_limit_order / sell_limit_order 또는 buy_market_order / sell_market_order이다. 업비트의 API 가이드에 따르면 이 함수들의 반환 값은 다음과 같다. 실제로 반환 값을 출력해보면 아래와 같이 딕셔너리의 형태로 이루어져 있는 것을 볼 수 있다. 여기서 우리가 반드시 기록할 필요가 있는 변수들이 무엇이 있을까? 기본적으로 매매한 코인명과 매매 시간, 매매한 양은 필요할 것이다. 따라..
[Toy Project] 자동매매 프로그램 만들기 - 6. openpyxl 모듈 알아보기 [목차] 1. openpyxl 모듈이란? 2. 엑셀 파일 불러오기 3. 셀의 데이터 불러오기 4. 엑셀 파일/시트 만들기 5. 셀에 데이터 작성하기 자동매매 프로그램으로 매매를 하는 경우, 내가 정한 매매 전략이 효과적으로 작용하는지 알아보기 위해서는 매매한 기록들을 모두 저장한 후 분석하는 과정이 필요하다. 하지만, 매번 매매한 정보를 직접 기록하는 것은 자동매매의 성격과 맞지 않으므로, 자동으로 매매를 수행할 때마다 이에 대한 정보를 실시간으로 알아서 기록해주는 기능이 필요하다. 따라서 이 기능을 프로그램에 적용하기 앞서, 파이썬을 이용하여 엑셀에 읽고 쓰는 기능을 할 수 있게 해주는 openpyxl 모듈에 대해서 먼저 알아보자. 1. openpyxl 모듈이란? 파이썬에서 엑셀을 다룰 수 있도록 하는..
[Toy Project] 자동매매 프로그램 만들기 - 5. RSI 지표 이용하여 매매하기 [목차] 1. 여러 암호화폐 RSI값 받아오기 2. RSI 지표 이용하여 매매 기능과 연동 1. 여러 암호화폐 RSI값 받아오기 이전 글에서 특정 암호화폐의 RSI값을 계산하는 방법을 알아보았다. RSI값을 계산하기 위해서는 pyupbit 모듈의 get_ohlcv 함수를 이용하여 해당 암호화폐의 이전 데이터들을 불러와야 한다. 하지만 get_ohlcv 함수로는 여러 암호화폐에 대한 데이터를 한 번에 받아올 수 없어서, 여러 암호화폐 RSI값을 계산하기 위해서는 각 암호화폐별로 get_ohlcv 함수를 각각 호출해야 한다. 따라서, 원하는 암호화폐 ticker를 리스트에 모아놓고, 차례대로 RSI를 계산하기로 했다. (더 나은 방법이 있는지는 잘 모르겠다) coinlist = ["KRW-BTC", "KRW..
[Toy Project] 자동매매 프로그램 만들기 - 4. RSI 지표 계산하기 [목차] 1. RSI 지표란? 2. RSI 지표 공식 3. 업비트 API를 통해서 RSI 계산하기 1. RSI 지표란? RSI(Relative Strength Index)는 상대강도지수로, 주식, 선물, 옵션 등의 기술적 분석에 사용되는 보조 지표이다. 1978년 미국의 Welles Wilder가 개발했다. RSI는 가격의 상승 압력과 하락 압력 간의 상대적인 강도를 나타내며, 일정 기간 동안 주가가 전일 가격에 비해 상승한 변화량과 하락한 변화량의 평균값을 구하여, 상승한 변화량이 크면 과매수로, 하락한 변화량이 크면 과매도로 판단하는 방식이다. Welles Wilder는 70% 이상을 과매수, 30% 이하를 과매도 상태로 규정했다. 2. RSI 지표 공식 RSI 지표의 식이 어떻게 유도되는지 알아보자..
[Toy Project] 자동매매 프로그램 만들기 - 3. pyupbit 모듈 알아보기 [목차] 1. pyupbit 모듈 설치 2. 암호화폐 목록 얻기 3. 암호화폐 현재가 얻기 4. 암호화폐 과거 데이터 조회 5. 암호화폐 호가 조회 6. 잔고 조회 7. 지정가 매수/매도 8. 시장가 매수/매도 9. 주문 취소/조회 1. pyupbit 모듈 설치 pyupbit 모듈이란, 업비트 API를 파이썬에서 쉽게 사용하기 위해서 저자들이 개발한 모듈이다. 굳이 API를 호출할 필요 없이 pyupbit 모듈을 이용하면 간편한 경우가 많다. pyupbit github 와 wikidocs.net/31063 를 참고하여 작성하였다. 먼저 pyupbit 모듈을 설치해보자. 프롬프트 창에 "pip install pyupbit"를 입력한다. 그 후, 다음 코드를 실행했을 때 오류가 발생하지 않는다면 pyupbi..
[Toy Project] 자동매매 프로그램 만들기 - 2. 업비트 API 가이드 업비트 개발자 센터에서는 API에서 제공하는 기능과 어떻게 사용할 수 있는지를 소개하고 있다. (docs.upbit.com/) Node, Python, Ruby, Java 총 4가지 언어에 대한 예시 코드가 나와있어 자신에게 맞는 언어를 선택하면 된다. 이제, 어떤 기능을 제공하고 있는지 알아보자. 먼저, 거래를 하기 위한 기능들이다. 1. 전체 계좌 조회 내가 현재 보유한 자산 리스트를 보여준다. 2. 주문 가능 정보 마켓별 주문 가능 정보를 확인한다. 여기서 마켓은 하나의 코인 종류를 생각하면 된다. 해당 코인에 대한 정보, 주문 가능한 범위, 조건 등을 제공한다. 3. 개별 주문 조회 주문 UUID(범용 고유 식별자)를 통해 개별 주문건을 조회한다. 4. 주문 리스트 조회 주문 리스트를 조회한다. ..
[Toy Project] 자동매매 프로그램 만들기 - 1. 업비트 API 사용 신청 암호화폐 자동매매 프로그램을 만들기 위해서는 기본적으로 거래소에서 제공하는 암호화폐에 대한 정보가 필요하다. 대부분의 큰 거래소들은 Open API를 제공하므로, 그중 국내에서 가장 거래량이 많은 업비트(Upbit) 거래소의 API를 사용하려고 한다. 먼저, 업비트 사이트의 회원가입 과정은 생략하겠다. 업비트 메인 홈페이지의 하단 부분을 보면 "Open API" 메뉴를 확인할 수 있다. 이를 클릭하자. Open API 사용하기를 누르면 Open API 이용 약관이 나온다. 여러 주의사항이 있는데, 대충 중요한 내용만 보면 다음과 같다. - 잔고 조회, 주문 기능(주문 조회, 주문하기), 출금 기능(출금 조회, 출금하기)을 사용할 수 있다. - 서비스의 장애 또는 중단으로 발생한 손해는 책임지지 않는다. ..