It's a game to get money.
파이썬 알고리즘기반 암호화폐 자동매매 프로그램. https://smtm.msalt.net
교보문고 - 암호화폐 자동매매 시스템 만들기 with 파이썬
예스24 - 암호화폐 자동매매 시스템 만들기 with 파이썬
알라딘 - 암호화폐 자동매매 시스템 만들기 with 파이썬
English 👈
데이터 수집 -> 알고리즘 분석 -> 거래로 이루어진 간단한 프로세스를 정해진 간격으로 반복 수행하는 것이 기본 개념이며, 기본적으로 분당 1회 프로세스를 처리하는 것으로 검증되었습니다.
- Data Provider 모듈이 데이터 취합
- Strategy 모듈을 통한 알고리즘 매매 판단
- Trader 모듈을 통한 거래 처리
--- 반복 --- - Analyzer 모듈을 통한 분석
❗ 초 단위의 짧은 시간에 많은 거래를 처리해야하는 고성능 트레이딩 머신으로는 적합하지 않으며, 처리 시간이 중요한 성능이 요구되는 경우 충분한 검토가 필요합니다.
- 시뮬레이션
- 멀티프로세스 대량시뮬레이션
- CLI 모드 자동 거래
- JupyterNotebook을 활용한 원격컨트롤
- 텔레그램으로 컨트롤 하는 자동거래
텔레그램 챗봇 모드를 사용하면 자동매매 프로그램을 텔레그램 메신저를 사용해서 컨트롤 할 수 있습니다.
텔레그램 챗봇 모드를 위해서는 챗봇을 만들고 API 토큰과 대화방 정보를 입력해서 구동해야 합니다.
Telegram Controller 모듈은 제공된 정보를 바탕으로 사용자와 텔레그램 메신저를 통해 입력을 받아 Operator를 컨트롤합니다.
시뮬레이션 모드을 통해 과거 거래 데이터를 바탕으로 시뮬레이션을 수행해서 결과를 확인할 수도 있습니다. 간단한 시뮬레이션부터 대량시뮬레이션까지 가능합니다.
소스 코드를 다운로드하고 관련된 패키지를 설치하세요.
pip install -r requirements.txt
시스템 수정 및 개발을 원할 때는 -e 옵션으로 개발관련 패키지도 설치하세요.
pip install -r requirements-dev.txt
시뮬레이션, 대량 시뮬레이션, 챗봇 모드를 포함하여 아래 6개의 기능을 제공합니다.
- 0: 인터렉티브 모드로 시뮬레이터
- 1: 입려받은 설정값으로 싱글 시뮬레이션
- 2: 기본 실전 매매 프로그램
- 3: 텔레그램 챗봇 모드로 실전 매매 프로그램
- 4: 컨피그 파일을 사용한 대량 시뮬레이션
- 5: 대량 시뮬레이션을 위한 컨피그 파일 생성
아래 명령어로 인터렉티브 모드 시뮬레이터 실행.
python -m smtm --mode 0
시뮬레이션 파라미터와 아래 명령어로 단일 시뮬레이션을 바로 실행 후 결과 반환.
python -m smtm --mode 1 --budget 500000 --from_dash_to 201220.080000-201221 --term 0.001 --strategy 1 --currency BTC
초기값과 함께 기본 실전 매매 프로그램을 실행. 기본 실전 매매 프로그램은 인터렉티브 모드로 실행되어 입력에 따라 거래 시작, 중지, 결과 조회가 가능합니다.
python -m smtm --mode 2 --budget 100000 --term 60 --strategy 0 --currency ETH
실전 거래를 위해서는 .env
파일에 거래소 API KEY와 API host url을 넣어 주어야 합니다.
UPBIT_OPEN_API_ACCESS_KEY=Your API KEY
UPBIT_OPEN_API_SECRET_KEY=Your API KEY
UPBIT_OPEN_API_SERVER_URL=https://api.upbit.com
아래 명령어로 텔레그램 챗봇 모드 실전 매매 프로그램을 실행. 텔레그램 챗봇 모드 실전 매매 프로그램은 입력받은 텔레그램 챗봇 API 토큰과 대화방 정보를 사용하여 텔레그램 챗봇 메세지를 통해서 거래 시작, 중지, 결과 조회가 가능합니다.
python -m smtm --mode 3
챗봇 모드를 위해서는 .env
파일에 텔레그램 챗봇 API 토큰과 챗봇 대화방 아이디를 넣어 주어야 합니다.
TELEGRAM_BOT_TOKEN=bot123456789:YOUR bot Token
TELEGRAM_CHAT_ID=123456789
대량 시뮬레이션 설정 파일과 함께 실행. 설정 파일을 json 형식이며 텍스트 편집기를 통해서 직접 생성해도 되고, 명령어를 통해 생성도 가능합니다.
python -m smtm --mode 4 --config /data/sma0_simulation.json
파라미터와 함께 아래 명령어로 대량 시뮬레이션에 사용될 설정 파일을 생성할 수 있습니다.
python -m smtm --mode 5 --budget 50000 --title SMA_6H_week --strategy 1 --currency ETH --from_dash_to 210804.000000-210811.000000 --offset 360 --file generated_config.json
계층화된 아키텍쳐 Layered architecture
Layer | Module | Role |
---|---|---|
Controller Layer | Simulator, Controller, TelegramController | User Interface |
Operator Layer | Operator, SimulationOperator | Operating Manager |
Core Layer | Analyzer, Trader, Strategy, Data Provider | Core Feature |
unittest를 사용해서 프로젝트의 단위 테스트를 실행.
# run unittest directly
python -m unittest discover ./tests *test.py -v
통합 테스트는 실제 거래소를 사용해서 테스트가 진행됩니다. 몇몇 테스트는 주피터 노트북을 사용해서 테스트가 가능하도록 하였습니다. notebook
폴더를 확인해 보세요.
# run unittest directly
python -m unittest integration_tests
# or
python -m unittest integration_tests.simulation_ITG_test
커밋을 생성하기 전에 아래 명령어를 사용하여 Jupyter notebook의 출력을 삭제하세요.
jupyter nbconvert --clear-output --inplace {file.ipynb}
#jupyter nbconvert --clear-output --inplace .\notebook\*.ipynb
시뮬레이션이나 데모 모드를 사용하는 경우, SimulationDataProvider는 업비트의 정보를 사용하므로, 시스템 시간의 타임존이 한국으로 설정되어야 합니다. 특히, 클라우트 리눅스의 경우 아래 명령어로 설정 할 수 있습니다.
timedatectl set-timezone 'Asia/Seoul'
원격 터미널에서 프로그램 실행 후 연결을 종료하더라도 프로그램이 종료되지 않도록 하기 위해서 nohup
을 사용하는 방법이 있습니다. 표준 출력과 에러를 별도의 파일에 저장하며 백그라운드로 실행하기 위해서는 다음과 같이 실행하면 됩니다.
nohup python -m smtm --mode 3 --demo 1 > nohup.out 2> nohup.err < /dev/null &