source push
This commit is contained in:
103
check_account_config.py
Normal file
103
check_account_config.py
Normal file
@@ -0,0 +1,103 @@
|
||||
#!/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()
|
||||
Reference in New Issue
Block a user