커뮤니티

예스스팟 오류메세지 관련 문의

프로필 이미지
기사단장
2023-01-18 21:22:03.0
1263
글번호 225763
답변완료

첨부 이미지

담당자님 안녕하세요. 항상 많은 도움 주셔서 감사드리며 덕분에 많은 발전을 이루고 있습니다. 기존에 올려주신 예스스팟 식을 참고하여 종목검색 후 차트 생성하여 시그널에 따다 매매를 일으키는 식을 작성하였습니다. 테스트를 위해 시험으로 가동하였는데, 첨부 스크린샷과 같이 '*계좌와 종목 불일치' 라는 오류메세지와 함께 매매가 거절당하였는데요 혹시 원인이 무엇인지 알 수 있을까요? 참고로 가려둔 계좌는 모두 동일한 계좌번호 입니다. 계좌 객체도 생성하였으며, 동일한 계좌번호와 연동시켜두었습니다. 참고차 작성한 수식도 공유드리오니 확인해주시면 감사하겠습니다. ------------------------------------------------------------------------- var 검색주기 = 180;//120초 var 최대종목수 = 30,M1; var ItemList = [],CT = []; var req; var JongmokNum ; var JongmokCode = new Array(10); var ChartSet = new Array(10); var SystemSet = new Array(10); //스팟 시작할때 파워종목검색의 사용자검색조건 실행 //스팟시작 function Main_OnStart() { //종목검색 타이머 Main.SetTimer(1,검색주기*1000)//300초, 1000이 1초 //잔고체크 타이머 Main.SetTimer(2,3000)//3초, 1000이 1초 Main.MessageList("start"); //종목당 매수금 M1 = Math.floor(Account1.GetBalanceETCinfo(0)/최대종목수);//하이기준 예수금 //주문종목갯수 CTcnt = 0; } //타이머동작 function Main_OnTimer(nEventID) { var d = new Date(); var HHMMSS = d.getHours()*10000+d.getMinutes()*100+d.getSeconds(); //9시 이후에 2분간격으로 종목검색 확장차트가가 50개 이하일때 반복적으로 검색 if (nEventID == 1 && HHMMSS >= 090000 && CT.length < 50) { Main.MessageList("종목검색 요청"); Main.ReqPowerSearch("통합종목검색"); //사용자검색조건명 지정 } } function Main_OnRcvItemList(aItemList, nCount) { Main.KillTimer(1); Main.MessageList("종목검색 완료 nCount : ",nCount); //보유종목수 var num = Account1.GetTheNumberOfBalances(); //검색된 종목이 1개이상 if (nCount > 0) { ItemList = []; //첫검색일때 if (CT.length == 0) { //옵션1. 개별 입력 + 최대 종목수 제한 for (var i = 0; i < Math.min(최대종목수-num,nCount); i++ ) { ItemList.push(aItemList[i]); } //옵션2. 배열 전체 입력 //ItemList = aItemList; } else //두번쨰 이후(차트가 만들어진 종목을 제외하고 새로운 종목만 집계) { for (var i = 0; i < nCount; i++ ) { var add = true; for (var x = 0; x < CT.length; x++ ) { if (aItemList[i] == CT[x].code) { add = false; } } if (add == true) { ItemList.push(aItemList[i]); if (ItemList.length == 최대종목수-num) { break; Main.MessageList("break: 최대종목수 도달"); } } } } Main.MessageList("종목검색 완료 ItemList :",ItemList.length); //집계된 종목이 1개 이상이면 순차적으로 차트객체 요청 if (ItemList.length > 0 && CT.length < 최대종목수) { req = 0; var TradeSet = new SystemTradeInfo(TRADE_FIXCOUNT, 1, //거래수량 100000, //자산 1, // 단위수량 0, 0, CALCMETHOD_PERCENT, // 진입/청산 수수료 0, 0, CALCMETHOD_POINT, // 진입/청산 슬리피지 PYRAMIDING_ALL, // 피라미딩 설정여부 1000, // 최대진입수량 20); // 최대진입횟수 var ChartSet = new ReqChartItem(ItemList[req],3,CHART_PERIOD_MINUTE,5000,CHART_REQCOUNT_BAR,false,false); var SystemSet = new SystemInfo("통합시스템", YL_TYPE_NORMAL, null, null, null); Main.MessageList("현재차트갯수 : ",CT.length); //다음 차트 객체 요청 Main.MessageList(req,"차트객체요청 : ",ItemList[req]); Main.ReqChartEx(ChartSet,SystemSet); } else //검색된 종목이 없으면 { if (CT.length < 최대종목수) { Main.SetTimer(1, 검색주기*1000);//종목검색 타이머 재실행 } } } } function Main_OnRcvChartEx(ChartEx) { if (ItemList[req] == ChartEx.GetCode(1)) { CT[CTcnt] = ChartEx; //차트 종목 코드 저장 Main.MessageList(CTcnt,"차트객체생성 : ",CT[CTcnt].GetCode(1)); CTcnt = CTcnt +1; req = req + 1; if (req < ItemList.length && CT.length < 최대종목수) { var TradeSet = new SystemTradeInfo(TRADE_FIXCOUNT, 1, //거래수량 100000, //자산 1, // 단위수량 0, 0, CALCMETHOD_PERCENT, // 진입/청산 수수료 0, 0, CALCMETHOD_POINT, // 진입/청산 슬리피지 PYRAMIDING_ALL, // 피라미딩 설정여부 1000, // 최대진입수량 20); // 최대진입횟수 var ChartSet = new ReqChartItem(ItemList[req],3,CHART_PERIOD_MINUTE,5000,CHART_REQCOUNT_BAR,false,false); var SystemSet = new SystemInfo("통합시스템", YL_TYPE_NORMAL, null, null, null); Main.MessageList("현재차트갯수 : ",CT.length); //다음 차트 객체 요청 Main.MessageList(req,"차트객체요청 : ",ItemList[req]); Main.ReqChartEx(ChartSet,SystemSet); } else { Main.MessageList("Search1 차트객체요청종료"); //만들어진 차트가 최대종목수 이하이면 if (CT.length < 최대종목수) { Main.SetTimer(1, 검색주기*1000);//120초 } } } } //신호발생 function Main_OnRiseSignal(ChartEx, Signal) { //신호발생 종목에 대해 잔고셋팅 Account1.SetBalance(Main.GetOrderCode(Signal.code),0); //매수신호이고 잔고가 없을때만 매수 if (Signal.signalKind == 1 && Account1.Balance.count == 0) { Account1.OrderBuy(Main.GetOrderCode(Signal.code),Math.floor(M1/Signal.price),0,1); Main.MessageLog("매수주문"); } if (Signal.signalKind == 2) { //전체미체결주문 갯수 var num = Account1.GetTheNumberOfUnfills(); //전체 미체결수 만큼 루프를 돌면서 for (var i = 0; i < num; i++) { //미체결을 하나씩 셋팅하고 Account1.SetUnfill(i); //미체결종목이 신호종목과 같고 미체결수량이 있으면 if (Account1.Unfill.code == Main.GetOrderCode(Signal.code) && Account1.Unfill.count > 0) { Account1.OrderCancel(Account1.Unfill.orderNum); Main.MessageLog("미체결 주문취소"); } } //잔고수량만큼만 매도 if (Account1.Balance.count > 0) { Account1.OrderSell(Main.GetOrderCode(Signal.code),Account1.Balance.count,0,1); Main.MessageLog("매도주문"); } } }
답변 1
프로필 이미지

예스스탁 예스스탁 답변

2023-01-19 16:31:56.0

안녕하세요 예스스탁입니다. 스팟에 설정된 계좌종류를 확인하시기 바랍니다. 주식종목을 주문하는데 스팟에 설정된 계좌는 선물계좌나 주식 주문이 불가능한 계좌 같습니다. 즐거운 하루되세요 > 기사단장 님이 쓴 글입니다. > 제목 : 예스스팟 오류메세지 관련 문의 > 담당자님 안녕하세요. 항상 많은 도움 주셔서 감사드리며 덕분에 많은 발전을 이루고 있습니다. 기존에 올려주신 예스스팟 식을 참고하여 종목검색 후 차트 생성하여 시그널에 따다 매매를 일으키는 식을 작성하였습니다. 테스트를 위해 시험으로 가동하였는데, 첨부 스크린샷과 같이 '*계좌와 종목 불일치' 라는 오류메세지와 함께 매매가 거절당하였는데요 혹시 원인이 무엇인지 알 수 있을까요? 참고로 가려둔 계좌는 모두 동일한 계좌번호 입니다. 계좌 객체도 생성하였으며, 동일한 계좌번호와 연동시켜두었습니다. 참고차 작성한 수식도 공유드리오니 확인해주시면 감사하겠습니다. ------------------------------------------------------------------------- var 검색주기 = 180;//120초 var 최대종목수 = 30,M1; var ItemList = [],CT = []; var req; var JongmokNum ; var JongmokCode = new Array(10); var ChartSet = new Array(10); var SystemSet = new Array(10); //스팟 시작할때 파워종목검색의 사용자검색조건 실행 //스팟시작 function Main_OnStart() { //종목검색 타이머 Main.SetTimer(1,검색주기*1000)//300초, 1000이 1초 //잔고체크 타이머 Main.SetTimer(2,3000)//3초, 1000이 1초 Main.MessageList("start"); //종목당 매수금 M1 = Math.floor(Account1.GetBalanceETCinfo(0)/최대종목수);//하이기준 예수금 //주문종목갯수 CTcnt = 0; } //타이머동작 function Main_OnTimer(nEventID) { var d = new Date(); var HHMMSS = d.getHours()*10000+d.getMinutes()*100+d.getSeconds(); //9시 이후에 2분간격으로 종목검색 확장차트가가 50개 이하일때 반복적으로 검색 if (nEventID == 1 && HHMMSS >= 090000 && CT.length < 50) { Main.MessageList("종목검색 요청"); Main.ReqPowerSearch("통합종목검색"); //사용자검색조건명 지정 } } function Main_OnRcvItemList(aItemList, nCount) { Main.KillTimer(1); Main.MessageList("종목검색 완료 nCount : ",nCount); //보유종목수 var num = Account1.GetTheNumberOfBalances(); //검색된 종목이 1개이상 if (nCount > 0) { ItemList = []; //첫검색일때 if (CT.length == 0) { //옵션1. 개별 입력 + 최대 종목수 제한 for (var i = 0; i < Math.min(최대종목수-num,nCount); i++ ) { ItemList.push(aItemList[i]); } //옵션2. 배열 전체 입력 //ItemList = aItemList; } else //두번쨰 이후(차트가 만들어진 종목을 제외하고 새로운 종목만 집계) { for (var i = 0; i < nCount; i++ ) { var add = true; for (var x = 0; x < CT.length; x++ ) { if (aItemList[i] == CT[x].code) { add = false; } } if (add == true) { ItemList.push(aItemList[i]); if (ItemList.length == 최대종목수-num) { break; Main.MessageList("break: 최대종목수 도달"); } } } } Main.MessageList("종목검색 완료 ItemList :",ItemList.length); //집계된 종목이 1개 이상이면 순차적으로 차트객체 요청 if (ItemList.length > 0 && CT.length < 최대종목수) { req = 0; var TradeSet = new SystemTradeInfo(TRADE_FIXCOUNT, 1, //거래수량 100000, //자산 1, // 단위수량 0, 0, CALCMETHOD_PERCENT, // 진입/청산 수수료 0, 0, CALCMETHOD_POINT, // 진입/청산 슬리피지 PYRAMIDING_ALL, // 피라미딩 설정여부 1000, // 최대진입수량 20); // 최대진입횟수 var ChartSet = new ReqChartItem(ItemList[req],3,CHART_PERIOD_MINUTE,5000,CHART_REQCOUNT_BAR,false,false); var SystemSet = new SystemInfo("통합시스템", YL_TYPE_NORMAL, null, null, null); Main.MessageList("현재차트갯수 : ",CT.length); //다음 차트 객체 요청 Main.MessageList(req,"차트객체요청 : ",ItemList[req]); Main.ReqChartEx(ChartSet,SystemSet); } else //검색된 종목이 없으면 { if (CT.length < 최대종목수) { Main.SetTimer(1, 검색주기*1000);//종목검색 타이머 재실행 } } } } function Main_OnRcvChartEx(ChartEx) { if (ItemList[req] == ChartEx.GetCode(1)) { CT[CTcnt] = ChartEx; //차트 종목 코드 저장 Main.MessageList(CTcnt,"차트객체생성 : ",CT[CTcnt].GetCode(1)); CTcnt = CTcnt +1; req = req + 1; if (req < ItemList.length && CT.length < 최대종목수) { var TradeSet = new SystemTradeInfo(TRADE_FIXCOUNT, 1, //거래수량 100000, //자산 1, // 단위수량 0, 0, CALCMETHOD_PERCENT, // 진입/청산 수수료 0, 0, CALCMETHOD_POINT, // 진입/청산 슬리피지 PYRAMIDING_ALL, // 피라미딩 설정여부 1000, // 최대진입수량 20); // 최대진입횟수 var ChartSet = new ReqChartItem(ItemList[req],3,CHART_PERIOD_MINUTE,5000,CHART_REQCOUNT_BAR,false,false); var SystemSet = new SystemInfo("통합시스템", YL_TYPE_NORMAL, null, null, null); Main.MessageList("현재차트갯수 : ",CT.length); //다음 차트 객체 요청 Main.MessageList(req,"차트객체요청 : ",ItemList[req]); Main.ReqChartEx(ChartSet,SystemSet); } else { Main.MessageList("Search1 차트객체요청종료"); //만들어진 차트가 최대종목수 이하이면 if (CT.length < 최대종목수) { Main.SetTimer(1, 검색주기*1000);//120초 } } } } //신호발생 function Main_OnRiseSignal(ChartEx, Signal) { //신호발생 종목에 대해 잔고셋팅 Account1.SetBalance(Main.GetOrderCode(Signal.code),0); //매수신호이고 잔고가 없을때만 매수 if (Signal.signalKind == 1 && Account1.Balance.count == 0) { Account1.OrderBuy(Main.GetOrderCode(Signal.code),Math.floor(M1/Signal.price),0,1); Main.MessageLog("매수주문"); } if (Signal.signalKind == 2) { //전체미체결주문 갯수 var num = Account1.GetTheNumberOfUnfills(); //전체 미체결수 만큼 루프를 돌면서 for (var i = 0; i < num; i++) { //미체결을 하나씩 셋팅하고 Account1.SetUnfill(i); //미체결종목이 신호종목과 같고 미체결수량이 있으면 if (Account1.Unfill.code == Main.GetOrderCode(Signal.code) && Account1.Unfill.count > 0) { Account1.OrderCancel(Account1.Unfill.orderNum); Main.MessageLog("미체결 주문취소"); } } //잔고수량만큼만 매도 if (Account1.Balance.count > 0) { Account1.OrderSell(Main.GetOrderCode(Signal.code),Account1.Balance.count,0,1); Main.MessageLog("매도주문"); } } }