커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내

안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
프로필 이미지
예스스탁
2026-02-27
4404
글번호 230811
지표
답변완료

아래 요청사항 중 수식포함 안된 것이 있습니다.

매수 매도 식이 포함 안되어 있습니다 추가 부탁드림디다 그림 참조하세요 매수: 과열권 평균 plot1(var1)가 상승하고 있고, 과열권 진입시 매수 매도 : 침체권의 평균 plot2(var2)가 하락하고 있고, 침체권 진입시 매도 > 예스스탁 님이 쓴 글입니다. > 제목 : Re : 수식부탁드립니다. > 안녕하세요 예스스탁입니다. 1 Input : Period(12), Period1(5), Period2(5); var : H1(0),L1(0),H2(0),L2(0); Value1 = StochasticsD(Period,Period1,PEriod2); Condition1 = value1 > 80; Condition2 = value1 < 20; if Condition1 == true and Condition1[1] == false Then{ H1 = H; L1 = L; } if Condition1 == true then { if h > H1 Then H1 = h; if l < L1 Then L1 = l; } if Condition1 == false and Condition1[1] == true Then var1 = (H1+L1)/2; if Condition2 == true and Condition2[1] == false Then{ H2 = H; L2 = L; } if Condition2 == true then { if h > H2 Then H2 = h; if l < L2 Then L2 = l; } if Condition2 == false and Condition2[1] == true Then var2 = (H2+L2)/2; plot1(var1); plot2(var2);
프로필 이미지
라떼처럼
2018-07-02
179
글번호 120220
시스템

흰둥이아빠 님에 의해서 삭제되었습니다.

프로필 이미지
흰둥이아빠
2018-07-02
2
글번호 120219
시스템
답변완료

질문드립니다

기존에는 매수금액을 수기로 입력해서 매매했는데 아래처럼 변경하니 스팟 확장차트에 신호가 아예 나오질 않네요 총 자산의 10%를 매수하도록 검토 부탁드립니다.(혹시 금요일에 타 증권사 보유종목을 입고 했는데 아직 반영이 안된건지요) 변경전 input : 매수금액(1000000); input : Per(5); var : Evol(0),Xcnt(0),OpenCond(false),Xcond1(false),Xcond2(false),Xcond3(false); if stime == 090000 Then { buy("b",AtMarket,def,Floor(매수금액/C)); } 변경 후 input : Per(5); var : Evol(0),Xcnt(0),OpenCond(false),Xcond1(false),Xcond2(false),Xcond3(false); var : accountNum(""),Num(0),cnt(0),sum(0),total(0); accountNum = "0000-0000-11";#계좌번호 Num = GetNumPositions(accountNum);#지정한 계좌의 보유종목수 #평가손익 합산 sum = 0; for cnt = 0 to Num-1{ sum = sum + GetPositionOpenPL(GetPositionSymbol(cnt,accountNum),accountNum); } #예수금+총평가손익 total = GetUnclearedDeposits; if stime == 090000 Then { buy("b",AtMarket,def,Floor((Total*0.10)/C)); } 그리고 종목검색조건 당일 제외 5일 평균 거래대금 > 100,000,000 과 당일제외 평균 거래량 > 100,000 수식 부탁드립니다.
프로필 이미지
가이츠
2018-07-02
189
글번호 120212
시스템
답변완료

문의드립니다.

볼린저밴드를 이용한 수식 부탁드립니다 1. 볼린저밴드 중앙선 기준으로 캔들봉이 중앙선을 물렸을경우 음봉 일경우 매도신호 양봉 일경우 매수신호 반대신호가 나오면 기존 계약수들은 청산후 반대신호진입 1-1 볼린저밴드 중앙성 기준으로 캔들봉이 중앙선을 확실히 내려온뒤 음봉 일경우 매도신호 반대는 매수신호 반대신호가 나오면 기존 계약수들은 청산후 반대신호진입 2. 진입 수량 조절 가능하게 부탁드립니다 예: 5계약 4계약 조절 가능하게. 3. 청산 각기 다른 조절 수를 부탁드립니다 (따로 조절 할수있게 부탁드립니다) 예) 1계약:20틱 청산 1계약:40틱 청산 1계약:60틱 청산 1계약 다음신호까지 4..시간 설정 10시 15분부터 오후 5시 이후 매매종료 .시간 설정 가능하게 부탁드립니다 수식 1번 하고 1-1 번 하고 쫌부탁드립니다 감사합니다.
프로필 이미지
곽민수
2018-07-02
184
글번호 120211
시스템
답변완료

수식재문의

아래 요청드렸던것인데 원하는대로 전달이 안되서요.. 지금 매수식 매도식 2개있는데 이걸 1개의 식으로 합칠 수 있게 부탁드립니다. input : p1(55),P2(20),atrp(10),n(2); var : cnt(0),h1(0),l1(0),h2(0),l2(0),atrv(0),T(0); var : entry(true); atrv = atr(atrp); if TotalTrades > TotalTrades[1] and IsExitName("atrbl",1) == false and PositionProfit(1) < 0 Then { entry = false; T = 0; } if entry == false Then { if crossup(H,h1) Then { T = 1; var1 = c; } if T == 1 Then { if L <= var1-atrv[1]*n Then { T = 0; entry = true; } if CrossDown(L,L2) Then { T = 0; entry = true; } } } H1 = DayHigh(1); L1 = daylow(1); H2 = DayHigh(1); L2 = daylow(1); for cnt = 1 to max(P1,P2) { if cnt <= P1 Then { if DayHigh(cnt) > H1 Then H1 = DayHigh(cnt); if DayLow(cnt) < L1 Then L1 = DayLow(cnt); } if cnt <= P2 Then { if DayHigh(cnt) > H2 Then H2 = DayHigh(cnt); if DayLow(cnt) < L2 Then L2 = DayLow(cnt); } } if MarketPosition == 0 and crossup(h,h1) and entry == true Then { buy("매수"); } if MarketPosition == 1 Then { ExitLong("atrbl",AtStop,EntryPrice-atrv*n); if CrossDown(l,l2) Then { ExitLong("청산"); } } 2 input : p1(55),P2(20),atrp(10),n(2); var : cnt(0),h1(0),l1(0),h2(0),l2(0),atrv(0),T(0); var : entry(true); atrv = atr(atrp); if TotalTrades > TotalTrades[1] and IsExitName("atrsl",1) == false and PositionProfit(1) < 0 Then { entry = false; T = 0; } if entry == false Then { if CrossDown(L,L1) Then { T = 1; var1 = c; } if T == 1 Then { if H >= var1+atrv[1]*n Then { T = 0; entry = true; } if CrossUp(h,H2) Then { T = 0; entry = true; } } } H1 = DayHigh(1); L1 = daylow(1); H2 = DayHigh(1); L2 = daylow(1); for cnt = 1 to max(P1,P2) { if cnt <= P1 Then { if DayHigh(cnt) > H1 Then H1 = DayHigh(cnt); if DayLow(cnt) < L1 Then L1 = DayLow(cnt); } if cnt <= P2 Then { if DayHigh(cnt) > H2 Then H2 = DayHigh(cnt); if DayLow(cnt) < L2 Then L2 = DayLow(cnt); } } if MarketPosition == 0 and CrossDown(L,L1) and entry == true Then { sell("매도"); } if MarketPosition == -1 Then { ExitShort("atrsl",AtStop,EntryPrice+atrv*n); if CrossUp(h,h2) Then { ExitShort("청산"); } }
프로필 이미지
렉쳐
2018-07-02
178
글번호 120208
시스템
답변완료

수식문의

안녕하세요 하기 수기에서 추가로 문의사항이 있어서 메일 드립니다. 검토 부탁드립니다. 하기 수식에서 한가지 더 추가하고 싶어서 문의 드립니다. S4가 진입하는 추가 조건으로 진입시점의 완성봉이 전일 종가가격보다 하단에 있을때 진입하게 부탁드립니다. B4rk 진입하는 추가 조건으로 진입시점의 완성봉이 전일 종가가격보다 상단에 있을때 진입하게 부탁드립니다. input : Period(20),dv(2); input : ADXP(14); var : ADXv(0,data1),DP(0,data1),DM(0,data1); var : BBmd1(0,data1),BBdn1(0,data1),bbup1(0,data1); var : BandB1(0,data1),HH1(0,data1),LL1(0,data1); var : BBmd2(0,data2),BBdn2(0,data2),bbup2(0,data2); var : T(0,data1); BBmd1 = data1(ma(C,Period)); BBdn1 = data1(BollBandDown(Period,Dv)); BBUp1 = data1(BollBandUp(Period,Dv)); BandB1 = data1(((C-BBDn1)/(BBUp1-BBdn1))*100); BBmd2 = data2(ma(C,Period)); BBdn2 = data2(BollBandDown(Period,Dv)); BBUp2 = data2(BollBandUp(Period,Dv)); ADXv = data1(ADX(ADXP)); DP = data1(DiPlus(ADXP)); DM = data1(DiMinus(ADXP)); if crossup(BandB1,90) Then HH1 = BandB1; if BandB1 > 90 and BandB1 > HH1 Then HH1 = BandB1; if CrossDown(BandB1,10) Then LL1 = BandB1; if BandB1 < 10 and BandB1 < LL1 Then LL1 = BandB1; if CrossDown(BandB1,90) Then { T = 0; if HH1 > 100 Then T = -1; if BBup2 < BBup1 then T = -2; } if CrossUp(BandB1,10) Then { T = 0; if HH1 < 0 Then T = 1; if BBdn2 > BBdn1 then T = 2; } if T == -1 and BBup2 < BBup1 then T = -2; if T == 1 and BBdn2 > BBdn1 then T = 2; if T == -2 and T != T[1] and DP < ADXv Then { T = 0; sell("s4"); } if T == 2 and T != T[1] and DM < ADXv Then { T = 0; buy("b4"); }
프로필 이미지
softtoug
2018-07-02
193
글번호 120201
시스템
답변완료

문의 드립니다.

상위주기 차트의 이평선을 표시하는 지표에 대한 어느 회원님의 질문에 예스스탁에서 답한 글번호 57878번(아래수식)과 관련하여 질문드립니다. 1. 아래의 수식으로 60분봉의 20이평선과 60이평선을 해외선물 5분봉 차트나 틱차트에 적용해 본 결과, 오일 골드 유로 등의 상품에서는 60분봉 이평선과 수치가 잘 맞아 만족하게 잘쓰고 있습니다. 그러나 항셍에 대해 적용해 본 바, 60분봉 이평선과 수치에 많은 차이가 있어 질문드립니다. 항셍에 대한 특별히 변경.적용해야할 부분이 있으면 아래 수식에서 수정을 부탁드립니다. 2. 아래 수식 중에서 Array : C1[150](0); 이 부분에 대한 주석 설명을 부탁드립니다. 150이란 숫자는 무엇을 의미하는 지요? 미리 감사드립니다. input : ntime1(60),P1(20),P2(60); var : S1(0),D1(0),TM(0),TF(0); var : cnt(0),sum1(0),mav1(0),sum2(0),mav2(0),sum3(0),mav3(0); Array : C1[150](0); if Bdate != Bdate[1] Then{ S1 = TimeToMinutes(stime); D1 = sdate; } if D1 > 0 then{ if sdate == D1 Then TM = TimeToMinutes(stime)-S1; Else TM = TimeToMinutes(stime)+1440-S1; TF = TM%ntime1; if Bdate != Bdate[1] or (Bdate == Bdate[1] and TF < TF[1]) Then { for cnt = 1 to 149 { C1[cnt] = C1[cnt-1][1]; } } C1[0] = C; if C1[P2] > 0 then{ sum1 = 0; sum2 = 0; for cnt = 0 to P2-1{ if cnt < P1 then sum1 = sum1+C1[cnt]; if cnt < P2 then sum2 = sum2+C1[cnt]; } mav1 = sum1/P1; mav2 = sum2/P2; plot1(mav1); plot2(mav2); } }
프로필 이미지
부엉이
2018-07-01
196
글번호 120198
지표
답변완료

Re : 다시 문의드립니다.

1.지난번 답변에 감사드립니다. 2.아래 첨부식은 종목검색으로는 안된다는 것은 알겠는데 매도청산의 신호가 나온 종목만 프린트를 할수는 없는지요?(엑셀 또는 텍스트) 3. 한종목은 되는데 나머지가 안되네요(종목검색과 전략챠트를 연동 시킬 경우) 4. 장마철 건강에 유의하시며 좋은 하루 되시길!!!!! Input : short(12),long(26),sig(9),시작날(7),종료날(1),당일수익틱수(10),텍스트표시소숫점자리수(0); input : Period(20); Var : MACDv(0),MACDS(0),MACDO(0),T1(0),T2(0),tx(0),NP(0),N1(0),Tcond(false),당일수익(0); var : daypl(0),Xcond(false),Bcond(false),Scond(false); NP = NetProfit; MACDv = MACD(short, long); MACDs = ema(MACDv,sig); MACDO = MACDV-MACDS; var1 = ma(C,Period); if MACDV > MACDS Then T1 = 1; Else T1 = -1; if var1 > var1[1] Then T2 = 1; Else T2 = -1; if sDATE == 시작날 or ( sDATE > 시작날 ) Then{ Tcond = true; Xcond = false; N1 = Np; } daypl = NP-N1; bcond = T1 == 1 and T2 == 1; Scond = T1 == -1 and T2 == -1; if Tcond == true and Xcond == false then{ if MarketPosition <= 0 and Bcond == true and Bcond[1] == false Then{ buy("매수"); tx = Text_New(sdate,stime,H,"매수 :"+NumToStr(C,텍스트표시소숫점자리수)); Text_SetStyle(tx,2,1); Text_SetColor(tx,RED); Text_SetBold(tx,1); Text_SetSize(tx,20); } if MarketPosition >= 0 and Scond == true and Scond[1] == false Then{ sell("S"); tx = Text_New(sdate,stime,H,":"+NumToStr(C,텍스트표시소숫점자리수)); Text_SetStyle(tx,2,1); Text_SetColor(tx,blue); Text_SetBold(tx,4); Text_SetSize(tx,5); } if MarketPosition == -1 Then{ ExitShort("매도유지"); tx = Text_New(sdate,stime,H,"SP:"+NumToStr(C,텍스트표시소숫점자리수)); Text_SetStyle(tx,2,1); Text_SetColor(tx,BLUE); Text_SetBold(tx,4); Text_SetSize(tx,15); } if MarketPosition == 1 Then ExitLong("bp",AtLimit,EntryPrice+당일수익-daypl); }
프로필 이미지
sungdong
2018-07-01
261
글번호 120197
시스템
답변완료

문의 드립니다

var : T1(0),Tcond(false),entrycount(0); if (sdate != sdate[1] and stime >= 91000) or (sdate == sdate[1] and stime >= 91000 and stime[1] < 91000) Then { Tcond = true; T1 = TotalTrades; } if (sdate != sdate[1] and stime >= 153000) or (sdate == sdate[1] and stime >= 153000 and stime[1] < 153000) Then { Tcond = false; if MarketPosition == 1 Then exitlong(); if MarketPosition == -1 Then ExitShort(); } if (sdate != sdate[1] and stime >= 183000) or (sdate == sdate[1] and stime >= 183000 and stime[1] < 183000) Then { Tcond = true; T1 = TotalTrades; } if (sdate != sdate[1] and stime >= 43000) or (sdate == sdate[1] and stime >= 43000 and stime[1] < 43000) Then { Tcond = false; if MarketPosition == 1 Then exitlong(); if MarketPosition == -1 Then ExitShort(); } if MarketPosition == 0 Then entrycount = TotalTrades-T1; Else entrycount = TotalTrades-T1+1; if Tcond == true then { if entrycount >= 0 then { 1,2,3 진입수식 } if entrycount >= 1 then { 4,5,6, 진입수식 } } 1. 첨부파일에 보면 ExitLong#16과 ExitShort#18이 어디서 어떻게 나온것인지 알수가 없습니다 왜 이렇게 나오는지와 이런 명령어를 하지 않기 위해서는 어떻게 해야하는지와 만일 함수를 변경해야 한다면 함수를 좀 부탁드립니다 또한 채널매수 채널매도 또한 명령이 오류가 된듯한데요..... 2. 위의 함수에서 30분 이후에 거래가 되네요 30분 이후에 청산후 거래를 정지하려면 어떻게 변경해야 하나요 야간장도 마찬가지 4시 30분이후에 청산후 거래를 아예정지하려면 어찌 해야하는지 알려주세요.... if (TotalTrades == 0 or (TotalTrades >= 1 and var1 == 1)) and 조건1 Then buy("b1"); if (TotalTrades == 0 or (TotalTrades >= 1 and var1 == 2)) and 조건2 Then buy("b2"); if (TotalTrades == 0 or (TotalTrades >= 1 and var1 == 3)) and 조건3 Then buy("b3"); #청산완료 if TotalTrades > TotalTrades[1] then { #b1로 진입후 청산되었는데 수익이면 if IsEntryName("b1",1) == true and PositionProfit(1) > 0 then var1 = 2; #b2로 진입후 청산되었는데 수익이면 if IsEntryName("b2",1) == true and PositionProfit(1) > 0 then var1 = 1; #b1로 진입후 청산되었는데 손실이면 if IsEntryName("b2",1) == true and PositionProfit(1) < 0 then var1 = 3; #b3로 진입후 청산되었는데 수익이면 if IsEntryName("b3",1) == true and PositionProfit(1) > 0 then var1 = 1; #b3로 진입후 청산되었는데 손실이면 if IsEntryName("b3",1) == true and PositionProfit(1) > 0 then var1 = 1; } 3. 위의 식에서 조건절이 (IF~then, IF~then, iF~then) 이렇게 여려게의 IF~then 구문으로 이루어졌을경우 어떻게 묶어주나요? {}로 묶어줬더니 오류가 뜨네요.... var : T1(0),Tcond(false),entrycount(0); if (sdate != sdate[1] and stime >= 91000) or (sdate == sdate[1] and stime >= 91000 and stime[1] < 91000) Then { Tcond = true; T1 = TotalTrades; } if (sdate != sdate[1] and stime >= 153000) or (sdate == sdate[1] and stime >= 153000 and stime[1] < 153000) Then { Tcond = false; if MarketPosition == 1 Then exitlong(); if MarketPosition == -1 Then ExitShort(); } if (sdate != sdate[1] and stime >= 183000) or (sdate == sdate[1] and stime >= 183000 and stime[1] < 183000) Then { Tcond = true; T1 = TotalTrades; } if (sdate != sdate[1] and stime >= 43000) or (sdate == sdate[1] and stime >= 43000 and stime[1] < 43000) Then { Tcond = false; if MarketPosition == 1 Then exitlong(); if MarketPosition == -1 Then ExitShort(); } if MarketPosition == 0 Then entrycount = TotalTrades-T1; Else entrycount = TotalTrades-T1+1; if Tcond == true then { if entrycount >= 0 then { 1번식 } if entrycount >= 1 then { if (TotalTrades == 0 or (TotalTrades >= 1 and var1 == 1)) and 1번식 Then buy("b1"); if (TotalTrades == 0 or (TotalTrades >= 1 and var1 == 2)) and 2번식 Then buy("b2"); if (TotalTrades == 0 or (TotalTrades >= 1 and var1 == 3)) and 3번식 Then buy("b3"); #청산완료 if TotalTrades > TotalTrades[1] then { #b1로 진입후 청산되었는데 수익이면 if IsEntryName("b1",1) == true and PositionProfit(1) > 0 then var1 = 2; #b2로 진입후 청산되었는데 수익이면 if IsEntryName("b2",1) == true and PositionProfit(1) > 0 then var1 = 1; #b1로 진입후 청산되었는데 손실이면 if IsEntryName("b2",1) == true and PositionProfit(1) < 0 then var1 = 3; #b3로 진입후 청산되었는데 수익이면 if IsEntryName("b3",1) == true and PositionProfit(1) > 0 then var1 = 1; #b3로 진입후 청산되었는데 손실이면 if IsEntryName("b3",1) == true and PositionProfit(1) > 0 then var1 = 1; } } } 4. 최종적으로는 이러한 식을 만들고 싶은데 위에서 보면 1번식이 두번사용되어지는데 동일하게 사용하면 안될것같아서요.... 어떻게 해야 할지 부탁드립니다 5. 개인적으로 수고하시는 에스스탁님께 계좌를 옮기고 싶은데요 어찌하면 될까요 늘 감사합니다
프로필 이미지
돌아온스머프
2018-07-02
252
글번호 120196
지표