커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

문의드립니다.

해외선물에서 20이평선을 기준으로 첫 봉이 종가상 20이평선을 돌파한 후 봉중에서 20이평선과 50틱 이상 차이가 나면 종가까지 기다리지 않고 즉시 매수신호가 나오게 하고 싶습니다. 매도신호는 그 반대입니다. 미리 노고에 감사드립니다.
프로필 이미지
카르마다
2025-04-04
279
글번호 189836
시스템
답변완료

검색식 부탁 드려요

*역배열 종목 검색식 부탁 드려요 첫번째배열 밑에서 60 120 240 (지수) 두번째배열 밑에서 120 60 240 (지수) 세번째배열 밑에서 120 240 480 (지수) 위의 세가지 배열을 같이 합쳐서 "1개의 검색식"으로 구현 할수 있도록 부탁드려요
프로필 이미지
일지매7
2025-04-03
305
글번호 189835
종목검색
답변완료

질문드리겠습니다

안녕하세요 질문 2가지 부탁드립니다 질문1) text_new 관련해서 질문드립니다 현재 메인차트 하단에 거래대금 지표를 따로 표시를 했는데요 text 함수로 봉 마다 거래대금 값 (var33 의 값) 을 나타내려고 합니다 텍스트 위치는 막대 (막대차트로 표현) 상단보다 조금 높은 위치로 해주세요 메인차트가 아니라 분리된 하단 차트에 나타내고 싶습니다 질문2) 수식에서 cc 배열 값을 연결하는 추세선 ttl2 배열을 만들어 주셨으면 합니다 cc 의 전값이 (cc[1]) 이 다음값 cc[0] 을 연결하는 추세선을 최근 "10개 까지만 보이게" 부탁합니다 수식은 질문1, 질문2 용으로 각각 올렸습니다 질문1 수식 = var : cnt(0), sum1(0), sumi1(0),summ(0),tt(0),hh(0),ll(0),tl(0),tl1(0),tx1(0); var: sum2(0),sumi2(0),sumaa(0); var : t(0),StartBarIndex(0),dd(0),d1(0),d2(0),ee(0),e1(0),e2(0); Array : ii[50](0),aa[50](0),bb[50](0),cc[50](0),vv[150](0),ttl[30](0); Var33=(floor(Money/100000000/10)*10); if Bdate != Bdate[1] Then DD = DD+1; #H>vi(1)*0.95 h>l*1.07 if h>min(l,l[1])*1.08 Then { d1 = dd; d2 = d1[1]; #if d1 >= d2+1 Then #if d2 == 0 or (d2 > 0 and d1 >= d2+3) Then if d2 == 0 or (d2 > 0 and d1 >= d2+5) Then { var1 = Index; Var2 = var1[1]; Var3= Var2[1]; sum1=0; sumi1=0; summ=0; For cnt = 1 to (var1-Var2) { sum1=sum1+h[cnt]; sumi1=sumi1+1; summ=summ+Var33[cnt]; } value1=sum1/sumi1; For cnt = 0 to 150 { vv[cnt]=0; } For cnt = 1 to (var1-Var2) { vv[cnt-1]=h[cnt]; } Plot12(summ,"Money",Orange,Def,1); tx1=text_new(sDate,sTime,l,""); } } 질문2 수식= var : cnt(0), sum1(0), sumi1(0),summ(0),tt(0),hh(0),ll(0),tl(0),tl1(0); var: sum2(0),sumi2(0),sumaa(0); var : t(0),StartBarIndex(0),dd(0),d1(0),d2(0),ee(0),e1(0),e2(0); Array : ii[50](0),aa[50](0),bb[50](0),cc[50](0),vv[150](0),ttl[30](0); if Bdate != Bdate[1] Then DD = DD+1; if h>min(l,l[1])*1.08 Then { d1 = dd; d2 = d1[1]; #if d1 >= d2+1 Then #if d2 == 0 or (d2 > 0 and d1 >= d2+3) Then if d2 == 0 or (d2 > 0 and d1 >= d2+5) Then { var1 = Index; Var2 = var1[1]; Var3= Var2[1]; sum1=0; sumi1=0; tl=TL_NEW(sDatE,sTimE,100,sDatE,sTimE,999999); TL_SetSize(tl,0); TL_SetColor(tl,Gray); For cnt = 1 to (var1-Var2) { sum1=sum1+h[cnt]; sumi1=sumi1+1; } value1=sum1/sumi1; For cnt = 0 to 150 { vv[cnt]=0; } For cnt = 1 to (var1-Var2) { vv[cnt-1]=h[cnt]; } Var20=Money/100000000; if Var20>30 Then { For cnt = 49 DownTo 1 { cc[cnt]= cc[cnt-1]; } cc[0]=value1*0.666; # Plot11(cc[0],"hma",Red,Def,1); } For cnt = 30 DownTo 1 { ttl[cnt] =ttl[cnt-1]; } TL_SetExtRight(ttl[10],False); ttl[0]=tl_new(sDate,sTime,cc[0],NextBarSdate,NextBarStime,CC[0]); TL_SetSize(ttl[0],1); TL_SetExtRight(ttl[0],true); } } Else { if CC[0] > 0 Then TL_SetEnd(ttl[0],sDate,sTime,CC[0]); }
프로필 이미지
yamu
2025-04-04
336
글번호 189834
지표

잔차 님에 의해서 삭제되었습니다.

프로필 이미지
잔차
2025-04-03
4
글번호 189833
종목검색
답변완료

문의 드립니다.

안녕하세요 ~ 아래의 매수선을 돌파하는 검색식 부탁 드립니다. A=highest(h,3); B=Lowest(L,3); D=(A+B)/2+(A-B)*0.382; d1=crossup(c,D)&& c>o*1.02; d2=crossdown(c,D); E=valuewhen(1, d1 or d2, o); e1=crossup(c,E); e2=crossdown(c,E); R=valuewhen(1, e1 or e2, o); r1=crossup(c,R); r2=crossdown(c,R); S=valuewhen(1, r1 or r2, o); T=wavg(S,2)*1.0062; wavg(T,2) 감사합니다.
프로필 이미지
ikksoo
2025-04-03
259
글번호 189832
검색
답변완료

하이킨아시

input : MaPeriod(2),MaPeriod2(1); var : maOpen(0),maClose(0),maLow(0),maHigh(0); var : haOpen(0),haClose(0),haLow(0),haHigh(0); var : ExtMapBuffer1(0),ExtMapBuffer2(0),ExtMapBuffer3(0),ExtMapBuffer4(0); Array : ExtMapBuffer5[100](0),ExtMapBuffer6[100](0),ExtMapBuffer7[100](0),ExtMapBuffer8[100](0); var : r(0),g(0),b(0), TL(0),t(0),tx(0); var : ii(0),cnt(0); var : sum1(0),sum2(0),sum3(0),sum4(0),csum(0); var : maOpen1(0),maClose1(0),maLow1(0),maHigh1(0); var : WMA1(0),WMA2(0),WMA3(0),WMA4(0); if Bdate != Bdate[1] Then { For cnt = 99 DownTo 1 { ExtMapBuffer5[cnt] = ExtMapBuffer5[cnt-1]; ExtMapBuffer6[cnt] = ExtMapBuffer6[cnt-1]; ExtMapBuffer7[cnt] = ExtMapBuffer7[cnt-1]; ExtMapBuffer8[cnt] = ExtMapBuffer8[cnt-1]; } ii = ii +1; maOpen1 = maOpen[1]; maClose1 = maClose[1]; maLow1 = maLow[1]; maHigh1 = maHigh[1]; } if ii == 0 Then { maOpen=dayOpen; maClose=dayClose; maLow=dayLow; maHigh=dayHigh; } Else { maOpen=(maOpen1*(MAperiod-1)+dayOpen)/MAPeriod; maClose=(maClose1*(MAperiod-1)+dayClose)/MAPeriod; maLow=(maLow1*(MAperiod-1)+dayLow)/MAPeriod; maHigh=(maHigh1*(MAperiod-1)+dayHigh)/MAPeriod; haOpen=(ExtMapBuffer5[1]+ExtMapBuffer6[1])/2; haClose=(maOpen+maHigh+maLow+maClose)/4; haHigh=Max(maHigh, Max(haOpen, haClose)); haLow=Min(maLow, Min(haOpen, haClose)); if (haOpen<haClose) then { r=255; g=10; b=0; ExtMapBuffer7[0]=haLow; ExtMapBuffer8[0]=haHigh; t = 1; } else { r=0; g=191; b=255; ExtMapBuffer7[0]=haHigh; ExtMapBuffer8[0]=haLow; t = -1; } ExtMapBuffer5[0]=haOpen; ExtMapBuffer6[0]=haClose; if ExtMapBuffer5[maPeriod2-1] > 0 Then { Sum1 = 0; Sum2 = 0; Sum3 = 0; Sum4 = 0; CSum = 0; For cnt = 0 To maPeriod2 - 1 { Sum1 = Sum1 + ExtMapBuffer7[cnt] * (maPeriod2 - cnt); Sum2 = Sum2 + ExtMapBuffer8[cnt] * (maPeriod2 - cnt); Sum3 = Sum3 + ExtMapBuffer5[cnt] * (maPeriod2 - cnt); Sum4 = Sum4 + ExtMapBuffer6[cnt] * (maPeriod2 - cnt); CSum = CSum + maPeriod2 - cnt; } ExtMapBuffer1 = Sum1/CSum; ExtMapBuffer2 = Sum2/CSum; ExtMapBuffer3 = Sum3/CSum; ExtMapBuffer4 = Sum4/CSum; plot1(ExtMapBuffer1); plot2(ExtMapBuffer2); plot3(ExtMapBuffer3); plot4(ExtMapBuffer4); } } 지난번 일봉을 분봉 답변해 주신건데요.타주기 60분봉를 5분봉에 그리고 싶어서 해봤는데 다른 값이 나와 문의 합니다.
프로필 이미지
함지박
2025-04-03
353
글번호 189831
지표
답변완료

예스스팟 자동매수 시 주문가격 0원 증상 문의 드립니다.

감사합니다. 추가적으로 질문을 드리고 싶습니다. 제가 서적을 참조해서 작성해놓은 예스스팟식으로 자동 매수 매도 주문을 해놓으니까 캡쳐된 사진처럼 주문가격이 '0원'인데 혹시 이게 왜 이럴까요?ㅠㅠ 아래 코드 보시고 검토가 가능하실지 문의 드립니다. 시험 매매 돌려놓은 것입니다. 저는 일단 1주씩 '매수조건'으로 검색이 되는 즉시 시장가 매수 이후 '매도조건'일 경우 자동 매도가 되게 구현을 하고 싶습니다. 초보적인 질문을 계속 드려서 죄송합니다. var timer5 = 2; // 2초 var 매수금 = 100000; var OrderList = []; var MKList = []; var req; var 종목제한수 = 10; var Search; function Main_OnStart() { Main.SetTimer(1, timer5 * 1000); MKList = []; Search = 1; } function Main_OnTimer(nEventID) { var d = new Date(); YYYYMMDD = d.getFullYear() * 10000 + (d.getMonth() + 1) * 100 + d.getDate(); HHMMSS = d.getHours() * 10000 + d.getMinutes() * 100 + d.getSeconds(); if (nEventID == 1 && HHMMSS > 090000 && HHMMSS < 151800) { Main.MessageList(Search); if (Search == 1) { Main.ReqPowerSearch("매수조건"); } else { Main.ReqPowerSearch("매도조건"); } Main.KillTimer(1); } if (nEventID == 2) { Main.ReqMarketData(OrderList[req]); Main.KillTimer(2); } } function Main_OnRcvItemList(aItemList, nCount) { Main.MessageList(nCount); OrderList = []; if (Search == 1) { if (nCount >= 1) { if (MKList.length == 0) { OrderList = aItemList.slice(0, 종목제한수); } else { for (var a = 0; a < nCount; a++) { var Add = true; for (var b = 0; b < MKList.length; b++) { if (aItemList[a] == MKList[b].code) { Add = false; } } if (Add == true && !IsStockInAccount(aItemList[a])) { OrderList.push(aItemList[a]); if (OrderList.length >= 종목제한수) { break; } } } } if (OrderList.length == 0) { Main.SetTimer(1, timer5 * 1000); } else { req = 0; Main.ReqMarketData(OrderList[req]); } } Search = -1; } else { if (nCount >= 1) { for (var a = 0; a < aItemList.Length; a++) { for (var b = 0; b < MKList.length; b++) { if (aItemList[a] == MKList[b].code) { Account1.SetBalance(aItemList[a], 0); if (Account1.Balance.count > 0) { Account1.OrderSell(Account1.Balance.code,Account1.Balance.countc,0,1); } } } } } Main.SetTimer(1, timer5 * 1000); Search = 1; } } function Main_OnRcvMarketData(MarketData) { if (MarketData.code == OrderList[req]) { MKList.push(MarketData); if (!IsStockInAccount(MarketData.code)) { Account1.OrderBuy(MarketData.code, 1, 0, 1); Main.MessageList(MarketData.code + " 주식을 매수합니다."); } else { Main.MessageList(MarketData.code + " 주식은 이미 계좌에 있으므로 매수하지 않습니다."); } req = req + 1; if (req < OrderList.length) { var aa = Main.ReqMarketData(OrderList[req]); if (aa == -1) { Main.SetTimer(2, 15000); } } else { Main.SetTimer(1, timer5 * 1000); } } } function IsStockInAccount(stockCode) { var numberOfBalances = Account1.GetTheNumberOfBalances(); for (var i = 0; i < numberOfBalances; i++) { Account1.SetBalance(i); if (stockCode == Account1.Balance.code) { return true; } } return false; }
프로필 이미지
deeparc
2025-04-03
329
글번호 189827
시스템
답변완료

안녕하세요 문의드립니다.

매번 잘 알려주셔서 너무 감사합니다. 다름 아니라 아래 2가지 건 질문을 추가로 드릴려고 하는데 확인 한번 부탁드립니다. 1. 코인 시스템 구성을 하고 있는데 혹시 손절로 인한 매도(exitlong)이 실행되었을 경우 그 이후 10봉 까지는 매수 금지 뭐 그런 게 식으로 구현이 될지 문의를 드립니다. 2. 주식 예스트레이더(x64) 예스스팟으로 제가 매수/매도 조건식해놓고 있는데 매수 조건식으로 검색되는 종목이라도 매수가 안되는 경우가 많던데 이것도 혹시 예스트레이더 코인 처럼 계속 프로그램을 켜놔야 하나요? 3. 예스트레이더켜놓고 있어보니까(가상서버로) 자꾸 다음날 아침에는 접속이 끊어지고 그러던데 접속이 안끊어지게(코인처럼) 계속 켜놓을 수 있는 방법이 없는지(접속 끊김이 발생하지 않도록 할수 있는지) 문의 드립니다. 4. 마지막으로 제가 작성해놓은 예스스팟식으로 자동주문을 해놓으니까 캡쳐된 사진처럼 주문가격이 '0원'인데 혹시 이게 왜 이럴까요?ㅠㅠ 아래 코드 보시고 검토가 가능하실지 문의 드립니다. 초보적인 질문을 계속 드려서 죄송합니다. var timer5 = 2; // 2초 var 매수금 = 100000; var OrderList = []; var MKList = []; var req; var 종목제한수 = 10; var Search; function Main_OnStart() { Main.SetTimer(1, timer5 * 1000); MKList = []; Search = 1; } function Main_OnTimer(nEventID) { var d = new Date(); YYYYMMDD = d.getFullYear() * 10000 + (d.getMonth() + 1) * 100 + d.getDate(); HHMMSS = d.getHours() * 10000 + d.getMinutes() * 100 + d.getSeconds(); if (nEventID == 1 && HHMMSS > 090000 && HHMMSS < 151800) { Main.MessageList(Search); if (Search == 1) { Main.ReqPowerSearch("매수조건"); } else { Main.ReqPowerSearch("매도조건"); } Main.KillTimer(1); } if (nEventID == 2) { Main.ReqMarketData(OrderList[req]); Main.KillTimer(2); } } function Main_OnRcvItemList(aItemList, nCount) { Main.MessageList(nCount); OrderList = []; if (Search == 1) { if (nCount >= 1) { if (MKList.length == 0) { OrderList = aItemList.slice(0, 종목제한수); } else { for (var a = 0; a < nCount; a++) { var Add = true; for (var b = 0; b < MKList.length; b++) { if (aItemList[a] == MKList[b].code) { Add = false; } } if (Add == true && !IsStockInAccount(aItemList[a])) { OrderList.push(aItemList[a]); if (OrderList.length >= 종목제한수) { break; } } } } if (OrderList.length == 0) { Main.SetTimer(1, timer5 * 1000); } else { req = 0; Main.ReqMarketData(OrderList[req]); } } Search = -1; } else { if (nCount >= 1) { for (var a = 0; a < aItemList.Length; a++) { for (var b = 0; b < MKList.length; b++) { if (aItemList[a] == MKList[b].code) { Account1.SetBalance(aItemList[a], 0); if (Account1.Balance.count > 0) { Account1.OrderSell(Account1.Balance.code,Account1.Balance.countc,0,1); } } } } } Main.SetTimer(1, timer5 * 1000); Search = 1; } } function Main_OnRcvMarketData(MarketData) { if (MarketData.code == OrderList[req]) { MKList.push(MarketData); if (!IsStockInAccount(MarketData.code)) { Account1.OrderBuy(MarketData.code, 1, 0, 1); Main.MessageList(MarketData.code + " 주식을 매수합니다."); } else { Main.MessageList(MarketData.code + " 주식은 이미 계좌에 있으므로 매수하지 않습니다."); } req = req + 1; if (req < OrderList.length) { var aa = Main.ReqMarketData(OrderList[req]); if (aa == -1) { Main.SetTimer(2, 15000); } } else { Main.SetTimer(1, timer5 * 1000); } } } function IsStockInAccount(stockCode) { var numberOfBalances = Account1.GetTheNumberOfBalances(); for (var i = 0; i < numberOfBalances; i++) { Account1.SetBalance(i); if (stockCode == Account1.Balance.code) { return true; } } return false; }
프로필 이미지
deeparc
2025-04-03
323
글번호 189823
시스템
답변완료

문의드립니다

input : n(5); var1= ma(c,n); if crossup (c, var1) then buy(); if crossdown (c, var1) then exitlong(); ----------------------------------- 차트속성에서 일간갭보정한 차트를 사용하는경우 위식을 적용하면 신호가 제대로 안나옵니다 갭보정한 차트에서 저 시스템을 식을 적용할수 있는 방법이 있을까요?
프로필 이미지
러블리
2025-04-03
322
글번호 189817
시스템
답변완료

수식부탁드립니다.

그림처럼 매도 진입 후 주가가 상승하여 손절하였으나 다시 하락하여 시가로 오면 시가에 재진입한다. 는 식을 만들 수 있는 가요?
프로필 이미지
산수유
2025-04-03
297
글번호 189816
시스템