Files
kis_bot/check_account_config.py
2026-02-22 18:05:14 +09:00

104 lines
4.3 KiB
Python

#!/usr/bin/env python3
"""
DB에서 계좌번호 설정 확인 스크립트
- 현재 최신 env_config에서 계좌번호 관련 필드 조회
- 모의/실전 구분 및 실제 읽히는 값 확인
"""
import sys
from pathlib import Path
SCRIPT_DIR = Path(__file__).resolve().parent
sys.path.insert(0, str(SCRIPT_DIR))
from database import TradeDB
def main():
db = TradeDB(db_path=str(SCRIPT_DIR / "quant_bot.db"))
env_data = db.get_latest_env()
db.close()
if not env_data or not env_data.get("snapshot"):
print("❌ env_config에 데이터가 없습니다.")
return
snapshot = env_data["snapshot"]
print(f"📊 최신 env_config (id={env_data['id']}, created_at={env_data['created_at']})\n")
# 모의 여부
kis_mock = snapshot.get("KIS_MOCK", "").lower()
is_mock = kis_mock in ("true", "1", "yes")
print(f"🔹 KIS_MOCK = '{kis_mock}' → 모의투자: {is_mock}\n")
# 실전 계좌
print("📌 실전 계좌 (KIS_MOCK=false 시 사용):")
acc_no_real = snapshot.get("KIS_ACCOUNT_NO", "").strip()
acc_code_real = snapshot.get("KIS_ACCOUNT_CODE", "").strip() or "01"
print(f" KIS_ACCOUNT_NO = '{acc_no_real}' ({len(acc_no_real)}자리)")
print(f" KIS_ACCOUNT_CODE = '{acc_code_real}' ({len(acc_code_real)}자리)")
if acc_no_real:
digits_no = "".join(c for c in acc_no_real if c.isdigit())
print(f" → 숫자만 추출: '{digits_no}' ({len(digits_no)}자리)")
if len(digits_no) >= 10:
print(f" → CANO: '{digits_no[:8]}', ACNT_PRDT_CD: '{digits_no[8:10]}'")
elif len(digits_no) == 8:
print(f" → CANO: '{digits_no}', ACNT_PRDT_CD: '{acc_code_real.zfill(2)[:2]}'")
else:
print(f" → ⚠️ 8자리 미만: CANO='{digits_no.zfill(8)[:8]}', ACNT_PRDT_CD='{acc_code_real.zfill(2)[:2]}' (부족한 자리 0으로 채움)")
else:
print(" → ❌ 값이 비어있음!")
print()
# 모의 계좌
print("📌 모의 계좌 (KIS_MOCK=true 시 사용):")
acc_no_mock = snapshot.get("KIS_ACCOUNT_NO_MOCK", "").strip()
acc_code_mock = snapshot.get("KIS_ACCOUNT_CODE_MOCK", "").strip() or "01"
print(f" KIS_ACCOUNT_NO_MOCK = '{acc_no_mock}' ({len(acc_no_mock)}자리)")
print(f" KIS_ACCOUNT_CODE_MOCK = '{acc_code_mock}' ({len(acc_code_mock)}자리)")
if acc_no_mock:
digits_no = "".join(c for c in acc_no_mock if c.isdigit())
print(f" → 숫자만 추출: '{digits_no}' ({len(digits_no)}자리)")
if len(digits_no) >= 10:
print(f" → CANO: '{digits_no[:8]}', ACNT_PRDT_CD: '{digits_no[8:10]}'")
elif len(digits_no) == 8:
print(f" → CANO: '{digits_no}', ACNT_PRDT_CD: '{acc_code_mock.zfill(2)[:2]}'")
else:
print(f" → ⚠️ 8자리 미만: CANO='{digits_no.zfill(8)[:8]}', ACNT_PRDT_CD='{acc_code_mock.zfill(2)[:2]}' (부족한 자리 0으로 채움)")
else:
print(" → ❌ 값이 비어있음! (fallback: 실전 계좌 사용)")
print()
# 실제 사용될 계좌
print("🎯 실제 사용될 계좌:")
if is_mock:
final_no = acc_no_mock or acc_no_real
final_code = acc_code_mock if acc_no_mock else acc_code_real
print(f" 모의투자 모드 → KIS_ACCOUNT_NO_MOCK='{acc_no_mock}' 또는 KIS_ACCOUNT_NO='{acc_no_real}'")
else:
final_no = acc_no_real
final_code = acc_code_real
print(f" 실전투자 모드 → KIS_ACCOUNT_NO='{acc_no_real}'")
if final_no:
digits_no = "".join(c for c in final_no if c.isdigit())
if len(digits_no) >= 10:
cano = digits_no[:8]
acnt = digits_no[8:10]
elif len(digits_no) == 8:
cano = digits_no
acnt = final_code.zfill(2)[:2]
else:
cano = digits_no.zfill(8)[:8]
acnt = final_code.zfill(2)[:2]
if len(cano) == 8 and len(acnt) == 2:
print(f" ✅ 최종: CANO={cano}, ACNT_PRDT_CD={acnt}")
else:
print(f" ❌ 최종: CANO={cano}({len(cano)}자리), ACNT_PRDT_CD={acnt}({len(acnt)}자리) → OPSQ2000 발생 가능!")
else:
print(" ❌ 계좌번호가 비어있음 → OPSQ2000 발생!")
if __name__ == "__main__":
main()