커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1504
글번호 230811
답변완료
부탁드립니다
input : Period(20),d1(2);var : 중심(0),상단(0),하단(0),BBP(0);중심=ma(C,period); 상단=중심+(D1*std(c,period)); 하단=중심-(D1*std(c,period)); BBP=(C-하단)/(상단-하단)*100;if CrossUp(BBP,98) Then Find(1);조건보다 2호가 위에 주문을 걸어라 가능 한가요
2026-01-15
219
글번호 229838
답변완료
검색식과 종목검색식 부탁 드립니다
키움에서 사용하는 2개의 서식을 합친 서식입니다.조건검색식 요청 드립니다a = wavg(2*wavg((h+l)/2,length/2) - wavg((h+l)/2,length), floor(sqrt(length)));b = wavg(wavg(close,(length/2)/3)*3 - wavg(close,(length/2)/2) - wavg(close,(length/2)),(length/2));up = b > a ;ap = (HIGH+LOW+CLOSE)/3;esa = eavg(ap, 기간);d = eavg(abs(ap - esa),기간);ci = (ap - esa) / (0.015 * d);wt1 = eavg(ci, 기간2);wt2 = avg(wt1,4);UP and wt1>=wt2
2026-01-15
200
글번호 229832
답변완료
종목 검색식 부탁드립니다.
1 "첫봉" 즉 M 이 Ms 돌파할때 종목 검색식 부탁드려요. M= Macd(12,26); Ms=eavg(M,12); 2. " 첫봉" 즉 S 가 Ss 돌파할때 종목 검색식 부탁드려요. S=StochasticsSlow(12,5); Ss=eavg(S,8); 3. "첫봉" 즉 CC 가 Cs 돌파 할때 종목 검색식 부탁드려요. CC=CCi(9); Cs=eavg(CC,20); 4. "첫봉" 즉 종가가 20선 돌파힐때 종목 검색식 부탁드려요. M10=ma(C,20); 5. "첫봉" 즉 R 이 Rs 돌파 할때 종목 검색식 부탁드려요. R=Rsi(14); Rs=eavg(R,14); 6. "첫봉" 즉 Dp가 Dm을 돌파 할때 종목 검색식 부탁드려요. Dp =DiPlus(18); Dm=DiMinus(18); 7. 아래의 수식을 참고하여, 수식1)과 수식2)를 선으로 표현할때, "수식1) 이 수식2) 를 돌파"할때 모든종목 검색식 부탁드려요. ---아래---- 수식1) A=(C-lowest(C,period))/C*100; max(A,0) 수식2) B=(highest(C,period)-C)/C*100; max(B,0) 지표조건 period 60
2026-01-15
338
글번호 229826
답변완료
지표하나 부탁드립니다.
안녕하세요 지표쫌 부타드립니다. 1. 지난 20일동안 현재 고점이 직전고점(high>high[1]) 보다 높으면 +12. 지난 20일 동안 현재 저점이 직전의 저점(Low<Low[1])보다 낮으면 -13. 높지도 낮지도 않으면 0 4. 지난 20일동안 위 1+2의 합계 표현 5. 봉차트 위에 숫자로 볼 수 있도록 수식 부탁드립니다. 가능하지 않으면 단순지표로 부탁드립니다.
2026-01-15
241
글번호 229821
답변완료
조건검색 문의
신 = H - L;호 = MAX(C, O) - L;조건 = 신 / 호 > 2 AND H / C(1) > (1 + ㅂ / 100);라인 = VALUEWHEN(1, 조건, H);신호 = C > 라인 AND C(1) <= 라인(1);신호;일봉상 위 신호가 발생한 종목에 대해서 모두 검출할 수 있도록 도와주시면 감사드리겠습니다 (__)
2026-01-15
146
글번호 229820
답변완료
문의 드립니다.
안녕하세요 ~ 평소 많은 도움 주심에 감사 드립니다. 현재 캔들(또는 가격)이 아래의 1라인 & 2라인, 2개 라인을 동시에 돌파하거나, 1라인이 2라인을 돌파하는 종목의 검색식을 부탁 드립니다. 1라인.MID=MA(C,20);dev = 2 * stdev(C, 20);upperBB = MID + dev2라인. MID=MA(C,20);RNG=ATR(20);MID+1.5*RNG감사합니다.
2026-01-15
207
글번호 229819
답변완료
파라볼릭 박스
아래 차트의 선만 있을 때는 박스 오류가 안보이는데, (근본적인 한계인지?)윗 차트의 박스를 주가 상하단에 맞춰 왼쪽으로 옮기니, 상하가 일치하지 않습니다.선물 400틱 차트입니다. 검토 부탁드립니다.Input : af(0.02), maxAF(0.2);var : T(0),TL(0),B(0),S(0),tx(0),txx(0),HH(0),HD(0),HT(0),LL(0),LD(0),LT(0),box(0);var : B1(0),B2(0),S1(0),S2(0),H1(0),H2(0),L1(0),L2(0);var : tx1(0),tx2(0),tx3(0),tx4(0),tx5(0),tx6(0);var1 = CSar(af,maxAF);plot1(var1, "CSAR",IFF(c>var1,Red,Green)); if CrossUp(C,var1) Then{ B = var1; T = 1; B1 = B[1]; B2 = B1[1]; HD = sDate; HT = sTime; HH = H; H1 = HH[1]; H2 = H1[1]; if LL > 0 Then box = Box_New(LD,LT,LL,HD,HT,HH); if abs(S-LL) < 1.25 Then Text_Delete(tx); tx = Text_New(sDate,sTime,HH,NumToStr(abs(HH-B),2)); Text_SetColor(tx,Red); Text_SetSize(tx,22); Text_SetStyle(tx,1,1); Text_SetBold(tx,1); Condition1 = False;}if CrossDown(C,var1) Then{ S = var1; T = -1; S1 = S[1]; S2 = S1[1]; LD = sDate; LT = sTime; LL = L; L1 = LL[1]; L2 = L1[1]; if HH > 0 Then box = Box_New(HD,HT,HH,LD,LT,LL); if abs(B-HH) < 1.25 Then Text_Delete(tx); tx = Text_New(sDate,sTime,LL,NumToStr(abs(LL-S),2)); Text_SetColor(tx,Blue); Text_SetSize(tx,22); Text_SetStyle(tx,1,0); Text_SetBold(tx,1); Condition1 = False; }Else{ if T == 1 Then { if H >= HH Then { HD = sDate; HT = sTime; HH = H; } Text_SetString(tx,NumToStr(abs(HH-B),2)); Text_SetLocation(tx,sDate,sTime,HH); Box_SetEnd(box,HD,HT,HH); if HH < LL+1.5 Then { Box_SetColor(box,Magenta); Box_SetFill(box,true,60); } Else if HH >= LL+1.5 and HH < LL+3.5 Then { Box_SetColor(box,Gray); Box_SetFill(box,true,60); } Else { Box_SetColor(box,Orange); Box_SetFill(box,true,40); } if abs(HH-LL) >= 2 Then { if Condition1 == False Then { Condition1 = true; tx1 = Text_New(HD,HT,HH+abs(HH-LL)*0.618,"●"); tx2 = Text_New(HD,HT,HH+abs(HH-LL)*1.000,"●"); tx3 = Text_New(HD,HT,HH+abs(HH-LL)*1.618,"●"); Text_SetStyle(tx1,2,2); Text_SetStyle(tx2,2,2); Text_SetStyle(tx3,2,2); Text_SetColor(tx1,Red); Text_SetColor(tx2,Blue); Text_SetColor(tx3,Red); tx4 = Text_New(HD,HT,LL-abs(HH-LL)*0.618,"●"); tx5 = Text_New(HD,HT,LL-abs(HH-LL)*1.000,"●"); tx6 = Text_New(HD,HT,LL-abs(HH-LL)*1.618,"●"); Text_SetStyle(tx4,2,2); Text_SetStyle(tx5,2,2); Text_SetStyle(tx6,2,2); Text_SetColor(tx4,Red); Text_SetColor(tx5,Blue); Text_SetColor(tx6,Red); } Else { Text_SetLocation(tx1,HD,HT,HH+abs(HH-LL)*0.618); Text_SetLocation(tx2,HD,HT,HH+abs(HH-LL)*1.000); Text_SetLocation(tx3,HD,HT,HH+abs(HH-LL)*1.618); Text_SetLocation(tx4,HD,HT,LL-abs(HH-LL)*0.618); Text_SetLocation(tx5,HD,HT,LL-abs(HH-LL)*1.000); Text_SetLocation(tx6,HD,HT,LL-abs(HH-LL)*1.618); } } } if T == -1 Then { if L <= LL Then { LD = sDate; LT = sTime; LL = L; } Text_SetString(tx,NumToStr(abs(LL-S),2)); Text_SetLocation(tx,sDate,sTime,LL); Box_SetEnd(box,LD,LT,LL); if LL > HH-1.5 Then { Box_SetColor(box,Lime); Box_SetFill(box,true,80); } Else if LL <= HH-1.5 and LL > HH-3.5 Then { Box_SetColor(box,Cyan); Box_SetFill(box,true,70); } Else { Box_SetColor(box,Cyan); Box_SetFill(box,true,50); } if abs(HH-LL) >= 2 Then { if Condition1 == False Then { Condition1 = true; tx1 = Text_New(LD,LT,HH+abs(HH-LL)*0.618,"●"); tx2 = Text_New(LD,LT,HH+abs(HH-LL)*1.000,"●"); tx3 = Text_New(LD,LT,HH+abs(HH-LL)*1.618,"●"); Text_SetStyle(tx1,2,2); Text_SetStyle(tx2,2,2); Text_SetStyle(tx3,2,2); Text_SetColor(tx1,Red); Text_SetColor(tx2,Blue); Text_SetColor(tx3,Red); tx4 = Text_New(LD,LT,LL-abs(HH-LL)*0.618,"●"); tx5 = Text_New(LD,LT,LL-abs(HH-LL)*1.000,"●"); tx6 = Text_New(LD,LT,LL-abs(HH-LL)*1.618,"●"); Text_SetStyle(tx4,2,2); Text_SetStyle(tx5,2,2); Text_SetStyle(tx6,2,2); Text_SetColor(tx4,Red); Text_SetColor(tx5,Blue); Text_SetColor(tx6,Red); } Else { Text_SetLocation(tx1,LD,LT,HH+abs(HH-LL)*0.618); Text_SetLocation(tx2,LD,LT,HH+abs(HH-LL)*1.000); Text_SetLocation(tx3,LD,LT,HH+abs(HH-LL)*1.618); Text_SetLocation(tx4,LD,LT,LL-abs(HH-LL)*0.618); Text_SetLocation(tx5,LD,LT,LL-abs(HH-LL)*1.000); Text_SetLocation(tx6,LD,LT,LL-abs(HH-LL)*1.618); } } }}
2026-01-15
721
글번호 229818
답변완료
진입 수량 및 청산 관련 문의
(중략)var: SL1(1000);If SL1 > 0 Then setstoploss((SL1/BigPointValue),PointStop);청산 관련하여 위 수식을 사용 중에 있는데손절은 1,000달러로 고정하여 청산하도록 청산 수식을 걸었고, 한번 진입 시 진입 수량을 5개 매수하도록 세팅하였습니다.이 경우, 위 청산 수식에 따라 해당 진입으로 인해 진입 수량 5개의 전체 손실 금액이 1,000달러 인 경우 청산하는 것인지 (총 손실 1,000달러 시 청산)아니면 진입 수량 5개 각각의 손실 금액이 1,000달러인 경우 청산하는 것인지 (총 5,000달러 손실 시 청산)문의 드립니다.
2026-01-15
319
글번호 229817
답변완료
수식 요청드립니다.
안녕하세요.수식 문의드립니다.피라미딩으로 누적 5계약까지 매수 또는 매도 진입한다고 하였을때5계약이 모두 진입된 상태에서 손실이 200pt가 되면 모두 손절하는 수식을 부탁드립니다.감사합니다.
2026-01-15
127
글번호 229816