답변완료
옵션 만기일 거래 시스템
수고하십니다.
아래의 옵션매매 시스템을 보완하고 싶습니다.
1. 장개시시 잔고종목 및 수량 확인
2. 청산신호시 잔고수량을 확인하여 전체 잔고 종목 및 수량을 청산
3. 만기일 1500시이후 옵션 당월물 보유수량 전체를 청산하고 차월물 진입
----------------------------------------------------------------------
var Start;
var BuyC1_code;
var BuyC2_code;
var BuyP1_code;
var BuyP2_code;
var SellC1_code;
var SellC2_code;
var SellP1_code;
var SellP2_code;
function Main_OnStart()
{
Main.MessageLog("시작");
Start = 0;
}
function Chart1_OnRiseSignal(Signal)
{
Main.MessageLog("신호완성/"+Signal.signalKind);
//Buy 신호발생
if (Signal.signalKind == 1 )
{
Start = 1;
SellP1_code = Option.GetATMPutRecent(0,0); //풋 ATM 종목코드
var SellP1_price = Option.GetBidByCode(SellP1_code,2);
var Vol = Signal.count; //신호수량
Account1.OrderSell(SellP1_code, Vol, SellP1_price, 0);
Main.MessageLog("상방합성선물매수");
}
//매수청산신호
if (Start == 1 && Signal.signalKind == 3 )
{
var BxP1_price = Option.GetAskByCode(SellP1_code, 2);
var Vol = Signal.count; //신호수량
Account1.OrderBuy(SellP1_code, Vol, BxP1_price, 0);
Main.MessageLog("상방합성선물매수청산");
}
//Sell 신호발생
if (Signal.signalKind == 3 )
{
Start = 1;
SellC1_code = Option.GetATMCallRecent(0,0); //콜 ATM 종목코드
var SellC1_price = Option.GetBidByCode(SellC1_code,2);
var Vol = Signal.count; //신호수량
Account1.OrderSell(SellC1_code, Vol, SellC1_price , 0);
Main.MessageLog("하방합성선물매도");
}
//매도청산신호
if (Start == 1 && Signal.signalKind == 1 )
{
var SxC1_price = Option.GetAskByCode(SellC1_code, 2);
var Vol = Signal.count; //신호수량
Account1.OrderBuy(SellC1_code, Vol, SxC1_price, 0);
Main.MessageLog("하방합성선물매도청산");
}
}
2019-04-15
2845
글번호 224804
문의 드립니다
수고 많으십니다
아래의 내용으로 예스스팟 전략을 작성하였는데 작동이 문제됩니다
하고자 하는 내용은
1. 차트 2개를 이용하여 미완성 신호가 동일방향에서 오면 매수,매도는 지정가로 하고, 청산은 시 장가로 전략을 작성코자 합니다.
2. 예스스팟 자체 전략으로 스톱로스를 걸고 싶은데 어떻게 하는 것인지 궁금합니다.
Q&A와 예제를 이용하여 작성해 보았지만 아래 식으로 해도 에러메시지만 뜹니다
감사합니다
//========================================================================
미완성신호
/*1. 봉 하나에서 발생하는 미완성 신호를 카운트 하여 처음 발생한 미완성 신호에 신호가 발생.
2.청산시에 미체결잔고를 셋팅하여 직전에 미체결된 주문이 있으면 주문을 취소하고 잔고의 수량만큼만 청산되게 작성했습니다.
3.모든 주문은 시장가 설정.기존에 작성한 주문가격은 모두 지정가로 현재가나 매수/매도 2호가 주문.
4.시험적용은 주문을 내지 않으므로 수식내용 중 주문과 관련된 내용은 시험적용에서는 동작을 하지 않습니다.
5 아래식 참고하셔서 수정/보완해 사용하시기 바랍니다. */
/*스크립트시작-----------------------------------------------------*/
var Position;
var BID;
var SID;
var Snum;
var Bnum;
var InCnt;
var Pb;
var Ps;
var pst;
function Main_OnStart()
{
Main.MessageLog("시작");
Position = 0;
pst=0;
}
function C1_OnBarAppended(nData) //봉완성(다음봉 시가수신) 새로운봉 시가 수신되면 직전봉이 완성됨
{
InCnt = 0;//봉의 시가가 수신되면 미완성신호 카운트를 0으로 초기화
Main.MessageList("봉완성",InCnt);
}
function C1_OnRiseIncompleteSignal(IncompleteSignal)//미완성 신호 발생
{
Main.MessageList("미완성신호 발생 - 종류 :"+IncompleteSignal.signalKind);
if (InCnt == 0 && IncompleteSignal.signalKind == 1 && Position <= 0 && Chart2.GetOpenContracts()>=1 )//Position이 0이하에서 buy미완성 신호 발생하면
{
pst=1;
InCnt = InCnt+1//카운트는 1
Position = 1;//Position은 1
BID = A1.OrderBuy(MarketData1.code,Signal.count,MarketData1.Ask(1),2);//신호에서 발생한 수량으로 지정가로 매수주문
Main.MessageList("매수진입",Position);
Pb = IncompleteSignal.price; //최초매수가
}
if (pst==1 && InCnt == 0 && IncompleteSignal.signalKind == 2 && Position == 1 )//Position은 1이고 ExitLong 미완성 신호가 발생하면
{
InCnt = InCnt+1;//카운트 증가
A1.SetUnfillOrderNumber(BNum);//BNum 번호에 대해 미체결객체 셋팅
if (A1.Unfill.count > 0 )//셋팅된 미체결객체의 수량이 0이상이면 취소주문
A1.OrderCancel(BNum);
A1.SetBalanceIndex(Main.GetOrderCode(M1.code)); //선물 잔고 셋팅
if (A1.Balance.count > 0 && A1.Balance.position == 2)//선물 잔고수량이 0이상이고 잔고가 매수포지션이면
{
A1.OrderSell(Main.GetOrderCode(M1.code), A1.Balance.count,0,1);//잔고의 수량 전량을 시장가로 모두 청산
Main.MessageList("매수청산실행",Position);
pst=0;
}
}
if (InCnt == 0 && IncompleteSignal.signalKind == 3 && Position >= 0 && Chart1.GetOpenContracts()>=1) )//Position이 0이상에서 Sell미완성 신호 발생하면
{
pst=-1;
InCnt = InCnt+1//카운트는 1
Position = -1;//Position은 -1
SID = A1.OrderSell(MarketData1.code,Signal.count,MarketData1.Ask(1),2);//신호에서 발생한 수량으로 지정가로 매도주문
Main.MessageList("매도진입",Position);
Ps = IncompleteSignal.price; //최초매도가
}
if (pst==-1 && InCnt == 0 && IncompleteSignal.signalKind == 4 && Position == -1 )//Position은 -1이고 ExitShort 미완성 신호가 발생하면
{
pst=0;
InCnt = InCnt+1;//카운트 증가
A1.SetUnfillOrderNumber(SNum);//SNum 번호에 대해 미체결객체 셋팅
if (A1.Unfill.count > 0)
A1.OrderCancel(BNum);//셋팅된 미체결객체의 수량이 0이상이면 취소주문
A1.SetBalanceIndex(Main.GetOrderCode(M1.code));//선물 잔고 셋팅
if (A1.Balance.count > 0 && A1.Balance.position == 1)//선물 잔고수량이 0이상이고 잔고가 매도포지션이면
{
A1.OrderBuy(Main.GetOrderCode(M1.code), A1.Balance.count,0,1);//잔고의 수량 전량을 시장가로 모두 청산(매수주문)
Main.MessageList("매도청산실행",Position);
}
}
}
StopLoss(Pb-0.25); //자동으로 스톱로스 걸고 싶습니다
StopLoss(Ps+0.25); //자동으로 스톱로스 걸고 싶습니다
function Main_OnOrderResponse(OrderResponse) //주문응답
{
if (Position == 1 && OrderResponse.orderID == BID)//Position이 1인 상태에서 주문응답아이디와 BID가 같으면 BNum에 주문번호 저장
{
BNum = OrderResponse.orderNum;
}
if (Position == -1 && OrderResponse.orderID == SID)//Position이 -1인 상태에서 주문응답아이디와 SID가 같으면 SNum에 주문번호 저장
{
SNum = OrderResponse.orderNum;
}
}
/*스크립트끝-------------------------------------------------------*/
2019-04-09
3351
글번호 224792
new Date() 문의
현재 시각을 가져오는 방법이 예제에서 보니
var d = new Date() 이던데요,
1) 변수 d의 scope 특성상 다른 함수에서도 사용하려면 d를 글로벌변수로 선언하거나 각 변수별로 다시 선언하거나 해야할 거 같은데, d가 로컬변수로 사용되다면 함수를 종료할 때 자연히 소멸자가 불리워져서 메모리 문제가 없어질 거 같은데 맞나요?
2) 글로벌변수로 선언할 경우 delete d와 같은 문장으로 수동으로 소멸자를 불러해줘야 할 거 같은데, 문법이 맞는지요? 일단 아래 예1과 같이 해보았는데, 굳이 이렇게 할 필요없이 d를 각 함수의 local 변수로 선언해주고 예2와 같이 해도 문제가 없을까요? 동작은 되겠으나 메모리 문제가 발생하지 않는 깔끔한 방법을 선택하고자 합니다. 답변 부탁드립니다.
//tdelay는 입력변수로 3이라고 입력하면 3초로 인식하도록 하였습니다.
//예1
var d;
function Main_OnStart()
{
d = new Date();
var HHMMSS = d.getHours()*10000+d.getMinutes()*100+d.getSeconds();
var MMM = d.getMilliseconds();
Main.MessageList(HHMMSS+"."+MMM);
Main.SetTimer(1, tdelay*1000);
delete d;
}
function Main_OnTimer(nEventID)
{
d = new Date();
var HHMMSS = d.getHours()*10000+d.getMinutes()*100+d.getSeconds();
var MMM = d.getMilliseconds();
Main.MessageList(HHMMSS+"."+MMM);tdelay
Main.MessageList(tdelay+"초경과");
delete d;
}
//예1
function Main_OnStart()
{
var d = new Date();
var HHMMSS = d.getHours()*10000+d.getMinutes()*100+d.getSeconds();
var MMM = d.getMilliseconds();
Main.MessageList(HHMMSS+"."+MMM);
Main.SetTimer(1, tdelay*1000);
}
function Main_OnTimer(nEventID)
{
var d = new Date();
var HHMMSS = d.getHours()*10000+d.getMinutes()*100+d.getSeconds();
var MMM = d.getMilliseconds();
Main.MessageList(HHMMSS+"."+MMM);tdelay
Main.MessageList(tdelay+"초경과");
}
2019-04-08
3341
글번호 224783
종목객체의 종목을 코드에서 변경 가능한가요?
ReqMarketData는 TR방식으로 시세정보를 요청하는거 같네요.
그래서 계속 실시간에 호가나 현재가에 반응하는 걸 만들려고 하는데, 그건 MarketData 객체에 종목을 지정해놓고 timer를 걸어서 데이타를 조회하는 방법 밖엔 없나요?
그리고, 옵션 실시간 데이타에 반응하는 로직을 구현하려고 하는데 종목이 매일 동적으로 바뀌어야해서 사전에 미리 MarketData객체에 종목코드를 고정시키지 못하고 코드상에서 변수로 바꾸고 싶은데, 메소드를 봐서는 불가능해 보이네요. 어떻게 하면 내가 원하는 종목의 실시간 데이터를 코드상에서 지정하고 받을 수 있나요? (ReqMarketData는 TR방식으로 요청하는 것 같으니 이 방식 말고 다른 방법이 필요합니다)
그리고, OnUp*dateMarekt에 대한 설명을 찾아보니 종목객체를 설정하면 현재가, 호가, 예상체결가(이건 현재준비중이라고 메뉴얼에 되어있던데 아직도 준비중인지요?)가 변할때마다 이 이벤트함수가 불리워지는거 같은데, 위에 문의한 것처럼 종목객체의 종목을 수동으로 말고 코드상에서 바꿀 수 있는 방법은 없을지요?
2019-04-08
3381
글번호 224782
검색 이후 자동매매 부탁드립니다.
매번 많은 도움 감사드립니다.
아래 조건 만족하는 수식 작성 부탁드립니다.
1. 파워종목 검색 (검색식 명: test)으로 10분마다 종목 검색
2. 검색된 종목들을 거래량으로 sorting
3. sorting 된 결과에서 상위 3종목 매수주문
--> 3종목 모두 매수한 뒤, 이후 검색조건 만족하는 종목이 나올 시,
거래량 상위 3종목 추가 선정하여 매수, 단, 이전에 매수한 종목과 안겹치게...
4. 검색된 종목들에서 매도신호 발생 시(yeslang. 전략명: temp) 매도주문 (미완성 봉에서 매도주문)
5. 장종료 동시호가 때, 남은 잔량 전부 매도
꼭 부탁드립니다.
감사합니다.
2019-04-07
3475
글번호 224781
답변완료
옵션객체에서 호가데이터 값을 얻는 방법 문의
GetAsk나 GetBid류의 함수를 쓰면 될 거는 같은데 이건 매번 조회하는 방법일테니 timer를 사용해서 해야할 거 같은데 timer를 사용하지 않고 하려면 main에서 onupdat emarket()을 사용하면 되나요? onupdat emarket()를 사용하려면 reqmarketdata()로 호출할 종목에 대해서 실시간에 데이타가 onupdat emarket()으로 도달하나요? 그리고 request한 것을 중지시키거나 수정하고 싶을땐 어떤 함수를 사용하면 되나요?
그리고, 메인에서 reqmarketdata()를 사용하는 방법과 MarketData 객체를 사용해서 실시간 데이터를 받는 방법은 어떤 차이가 있는지요? 15초 60회 규칙에 문제 일으키지 않고 서버나 피씨에도 부하가 적절한 방법을 고르고자 해서 보다 구체적인 이해를 위해 질문드립니다.
그리고, 각각의 사용법에 대한 예제를 찾아보는 중인데, 예를 들어, 장 시작전 및 장 중에 호가, 호가잔량, 총잔량, 총건수 및 체결시세(현재가)를 보고자 하는 종목들을 가격의 크기 여부에 따라 교체해 가면서 시세를 받고자 하는 코드를 작성하고자 합니다. 참고할 만한 글 번호 또는 예제 부탁드립니다.
2019-04-05
3311
글번호 224777