답변완료
문의드립니다.
답변 감사드립니다.
해당 프로그램을 실행하니
refeneceError : Opiton is not defined
라는 에러가 나오는데요...
옵션 객체를 추가해줘야 하는건지요?
그럼 답변 부탁드리겠습니다.
> 예스스탁 님이 쓴 글입니다.
> 제목 : Re : Re : Re : 문의드립니다.
>
안녕하세요
예스스스탁입니다.
계좌종류별로 인덱스가 모두 다릅니다.
위탁계좌는 30번이 코스닥증거금현금
저축계좌는 30분이 금일재매매대상금액
선물옵션계좌는 30번이 주문가능현금
입니다.
계좌별로 인덱스에 따른 리턴값이 모두 다릅니다.
Account1 계좌객체에 계좌번호를 지정할때 선물옵션계좌로 지정하시면 됩니다.
예스스팟 도움말에서 해당 함수 설명 참고하시기 바랍니다.
즐거운 하루되세요
> 왼손잡이 님이 쓴 글입니다.
> 제목 : Re : Re : 문의드립니다.
> 자세한 답변 감사드립니다 .^^
몇가지 궁금한 사항이 있는데요.
1. var OrderAbleAmoney = Account1.GetBalanceETCinfo(30)*0.1
라고 표현해 주셨는데 30이란 코드가 코스닥 증거금 현금이라고 되어 있는데 옵션주문시 위 사항이 맞는지요?
그럼 확인 부탁드리겠습니다.
> 예스스탁 님이 쓴 글입니다.
> 제목 : Re : 문의드립니다.
>
안녕하세요
예스스탁입니다.
예스스팟 답변은 가이드라인정도입니다.
아래내용 참고하셔서 수정보완해 사용하시기 바랍니다.
스크립트객체화면 설정
계좌객체 추가 --> 속성에서 객체명은 Account1, 계좌번호지정
차트객체 추가 --> 속성에서 객체명은 Chart1, 차트 아이디 지정후 차트에 동일아이디 부여
옵션객체 추가 --> 속성에서 따로 지정하실 부분은 없습니다.
각객체 설정은 예스스팟 도움말 참고하시기 바랍니다.
var CallOrderCode,PutOrderCode,T;
function Main_OnStart()
{
T = 0;
}
function Chart1_OnRiseSignal(Signal)
{
if (T <= 0 && Signal.signalKind == 1)
{
Main.MessageList("--------------------------------------------");
Main.MessageList("Buy신호 발생");
var UNum = Option.uppersATM;
var LNum = Option.lowersATM;
var CallCode = new Array(UNum+LNum+1);
var CallPrice = new Array(UNum+LNum+1);
//콜옵션중 2.0에 가장 가까운 종목
//콜옵션 모든 종목을 현재가-2.0을 해서 절대값을 취해 저장
for (var i = -LNum; i <= UNum; i++)
{
CallPrice[i+LNum] = Math.abs(Option.GetCurrent(0, i)-2.0);
CallCode[i+LNum] = Option.GetATMCallRecent(i);
}
//저장된 절대값중 가장 작은 종목의 값과 종목코드 계산
var CC = 99999999;
CallOrderCode = "";
for (var i = -LNum; i <= UNum; i++)
{
if (CallPrice[i+LNum] < CC)
{
CC = CallPrice[i+LNum];
CallOrderCode = CallCode[i+LNum]
}
}
//종목을 찾았으면
if (CC < 99999999)
{
//주문가능현금의 10%
var OrderAbleAmoney = Account1.GetBalanceETCinfo(30)*0.1;
//주문가격
var OrderPrice = Option.GetAsk(CallOrderCode, 3);
//주문가능현금/(주문가격*50만원)
var Qty = Math.floor(OrderAbleAmoney/(OrderPrice*500000));
//1계약 이상 CallOrderCode종목 매수주문
if (Qty >= 1)
{
Account1.OrderBuy(CallOrderCode, Qty, OrderPrice, 0);
T = 1;
Main.SetTimer(1, 10000);//1번타이머 10초
}
}
}
if (T == 1 && Signal.signalKind == 2)
{
Account1.SetBalanceItem(CallOrderCode, 0);
//CallOrderCode 잔고가 있으면 매수3호가로 전량 매도
if (Account1.Balance.count > 0)
{
Account1.OrderSell(Account1.Balance.code, Account1.Balance.count , Option.GetBid(CallOrderCode, 3), 0);
T = 0;
}
}
if (T >= 0 && Signal.signalKind == 3)
{
Main.MessageList("--------------------------------------------");
Main.MessageList("Sell신호 발생");
var UNum = Option.uppersATM;
var LNum = Option.lowersATM;
var PutCode = new Array(UNum+LNum+1);
var PutPrice = new Array(UNum+LNum+1);
//풋옵션중 2.0에 가장 가까운 종목
//풋옵션 모든 종목을 현재가-2.0을 해서 절대값을 취해 저장
for (var i = -UNum; i <= LNum; i++)
{
PutPrice[i+UNum] = Math.abs(Option.GetCurrent(1, i)-2.0);
PutCode[i+UNum] = Option.GetATMPutRecent(i);
}
//저장된 절대값중 가장 작은 종목의 값과 종목코드 계산
var PP = 99999999;
PutOrderCode = "";
for (var i = -UNum; i <= LNum; i++)
{
if (PutPrice[i+UNum] < PP)
{
PP = PutPrice[i+UNum];
PutOrderCode = PutCode[i+UNum];
}
}
//종목을 찾았으면
if (PP < 99999999)
{
//주문가능현금의 10%
var OrderAbleAmoney = Account1.GetBalanceETCinfo(30)*0.1;
//주문가격
var OrderPrice = Option.GetAsk(PutOrderCode, 3);
//주문가능현금/(주문가격*50만원)
var Qty = Math.floor(OrderAbleAmoney/(OrderPrice*500000));
//1계약 이상 매수주문
if (Qty >= 1)
{
Account1.OrderBuy(PutOrderCode, Qty, OrderPrice, 0);
T = -1;
Main.SetTimer(2, 10000);//2번타이머 10초
}
}
}
if (T == -1 && Signal.signalKind == 4)
{
Account1.SetBalanceItem(PutOrderCode, 0);
//PutOrderCode 잔고가 있으면 매수3호가로 전량 매도
if (Account1.Balance.count > 0)
{
Account1.OrderSell(Account1.Balance.code, Account1.Balance.count , Option.GetBid(PutOrderCode, 3), 0);
T = 0;
}
}
}
function Main_OnTimer(nEventID)
{
//1번 타이머 동작 T가 1일이면(Buy신호 이후)
if (nEventID == 1 && T == 1)
{
//CallOrderCode 종목 잔고 셋팅해서
Account1.SetBalanceItem(CallOrderCode, 0);
//잔고의 현재가가 평단가의 20% 이상이면 추가매수
if (Account1.Balance.current >= Account1.Balance.avgUnitCost*1.20)
{
//1번 타이머종료
Main.KillTimer(1);
//주문가능현금의 10%
var OrderAbleAmoney = Account1.GetBalanceETCinfo(30)*0.1;
//주문가격
var OrderPrice = Option.GetAsk(CallOrderCode, 3);
//주문가능현금/(주문가격*50만원)
var Qty = Math.floor(OrderAbleAmoney/(OrderPrice*500000));
//1계약 이상 CallOrderCode종목 매수주문
if (Qty >= 1)
{
Account1.OrderBuy(CallOrderCode, Qty, OrderPrice, 0);
}
}
}
//2번 타이머 동작하고 T가 -1이면(Sell신호 이후)
if (nEventID == 2 && T == -1)
{
//PutOrderCode 종목 잔고 셋팅해서
Account1.SetBalanceItem(PutOrderCode, 0);
//잔고의 현재가가 평단가의 20% 이상이면 추가매수
if (Account1.Balance.current >= Account1.Balance.avgUnitCost*1.20)
{
//2번 타이머종료
Main.KillTimer(2);
//주문가능현금의 10%
var OrderAbleAmoney = Account1.GetBalanceETCinfo(30)*0.1;
//주문가격
var OrderPrice = Option.GetAsk(PutOrderCode, 3);
//주문가능현금/(주문가격*50만원)
var Qty = Math.floor(OrderAbleAmoney/(OrderPrice*500000));
//1계약 이상 매수주문
if (Qty >= 1)
{
Account1.OrderBuy(PutOrderCode, Qty, OrderPrice, 0);
}
}
}
}
즐거운 하루되세요
> 왼손잡이 님이 쓴 글입니다.
> 제목 : 문의드립니다.
> 수고하십니다.
연결선물에 시스템을 적용하고 있는데요.
1. 선물에서 시스템 매수 시그날시.
-> 콜옵션 2.0 근처가격 매수
-> 전체 자금의 10%
-> 진입이후 수익률 20%도달시 전체자금의 10% 추가매수
2. 선물에서 매도 시그날시
-> 풋옵션 2.0 근처가격 매수
-> 전체 자금의 10%
-> 진입이후 수익률 20%도달시 전체자금의 10% 추가매수
3. 청산시그날시 모두 청산
을 하고 싶습니다.
초보라 잘 부탁드립니다.
2015-04-06
1885
글번호 223402
답변완료
시세조회 건수제한.........
안녕하세요~~
현물로 예스스팟 공부중인데 갑작스런 장벽을 만났습니다.
시세조회 건수제한 오류(15초당 60건만 가능합니다. 13초 남았습니다.)
위의 문구가 나오면서 스팟이 더이상 진행이 되지않습니다.
혹시나 13초후 다음으로 연결해서 진행될걸로 기대했으나
실망으로 끝을 맺었습니다.
현재 코스피, 코스닥, 그외종목합이 2000정도 되는데 건수제한수가
너무 불합리하다고 봅니다.
예전에도 어떤분이 질문한게 있었는데 그당시 검토해 보겠다는 답변이 있었습니다.
그로부터 훨씬 지난 지금도 그대로입니다.
해결책은 없는건가요?
위문구처럼 13초후 이어서 조회를 계속한다든지
딜레이함수로 15초에 정확히 60건을 처리하게 한다든지,,,,,,,
고민을 해결해 주십시요~~~~
항상 수고해주셔서 감사합니다.
2015-04-03
1911
글번호 223401
답변완료
피라미딩 진입, 피라미딩 청산식 문의요
피라미딩 매수, 매도 문의 드립니다
1. 옵션이 9시 10분이후 시가보다 1만원이상 오른 상태면 2계약 매수
2. 1차매수후 매수가격에서 1만원씩 오를때마다 계속 1계약씩 매수하여 총 8계약 추가매수(총10계약 피라미딩)
3. 2계약 보유중일때는 평균 진입가격 -0.9 손절,
4. 3계약 이상 보유중일때 평균 진입가격 -0.5 손절
5. 진입가에서 10만원이상 올랐다가 하락시 진입가+9만원에서 1계약 익절
6. 진입가에서 9만원이상 올랐다가 하락시 진입가+8만원에서 1계약 매도
6.7진입가에서 5만원이상 올랐다가 5일선이 120일선을 데드크로스하면 현재보유계약의 절반 매도
2015-03-31
1828
글번호 223392
답변완료
수식 부탁드립니다.
아래는 게시판에 올라와 있는 종목검색후 자동주문하는 스팟식입니다. 아래와 같은 내용으로 수정부탁드립니다.
1. 파워종목검색에 검색된 종목이 잔고에 있으면 시장가로 청산하게 수정부탁드립니다.
안녕하세요
예스스탁입니다.
아래식 참고하셔서 수정보완해 사용하시기 바랍니다.
주문을 위해서는 검색뿐만 아니라 주문가격지정을 위해 해당 종목의 시세데이타도 필요합니다.
그러므로 종목검색 후에 종목객체를 생성해서 주문을 집행하게 됩니다.
수식은 아래 흐름으로 동작합니다.
5분단위로 사용자검색조건 실행하고
검색이 완료되어 검색된 종목이 있으면 잔고에 없는 종목에 한해서
1초단위로 해당종목의 종목객체를 생성해서 매도5호가로 주문을 집행합니다.
예수금은 스팟시작시에 예수금을 가져와 10%의 금액으로 주문합니다.
스크립트 객체화면에는 계좌객체(Account1)만 추가하시면 됩니다.
var EntryMoney;
var ItemList,Count;
//스팟시작
function Main_OnStart()
{
//타이머설정
Main.SetTimer(1, 300000);//간격(300초 5분)
EntryMoney = Math.floor(Account1.GetBalanceETCinfo(0)*10);
}
function Main_OnTimer(nEventID)
{
//타이머동작하면 사용자검색조건 실행
if (nEventID == 1)
{
Main.ReqPowerSearch("Stest");
Req = 0;
}
if (nEventID == 2 && Req < Count)
{
Main.ReqMarketData(ItemList[Req], 0, 0);
Req = Req+1;
Main.MessageList(ItemList[Req-1],Req);
}
}
//종목검색이 완료
function Main_OnRcvItemList(aItemList, nCount)
{
//검색종목수가 1개 이상이면
if (nCount >= 1)
{
ItemList = aItemList;
Count = nCount;
//잔고셋팅해서 보유종목이 아니면
Account1.SetBalanceItem(ItemList[0],0);
Main.MessageList(ItemList,Count,Account1.Balance.count);
if (Account1.Balance.count == 0)
{
//종목객체 생성 요청
Req = 1;
Main.ReqMarketData(ItemList[0], 0, 0);
Main.SetTimer(2, 1000);//간격(1초)
}
}
}
//요청한 종목객체가 생성되면
function Main_OnRcvMarketData(MarketData)
{
var Ob = MarketData;
var EntryVol = 0;
//1주 단위일 경우
if (Ob.tradeUnit == 1)
EntryVol = Math.floor(EntryMoney/Ob.current);
//10주 단위일 경우
if (Ob.tradeUnit == 10)
EntryVol = Math.floor(Math.floor(Math.floor(EntryMoney/Ob.Ask(5))/10)*10);
if (EntryVol > 0)
{
Account1.OrderBuy(Ob.code,EntryVol,Ob.Ask(5),0);
Main.RemoveMarketData(Ob);
}
}
2015-03-30
2040
글번호 223383