커뮤니티

예스랭귀지 Q&A

글쓰기

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

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

조건중첩 수식 작성 요청

항상 도움주셔서 감사드립니다. 1. 단순5이평, 20이평, 60이평중 어느하나를(or) 상향돌파하는 종목 검색식 2. 상승잉태확인형, 샛별형, 상승삼법형(rising three methods)중 어느하나에(or) 해당하는 종목 검색식 3. ((단순20이평 또는(or) 60이평 상향돌파)) 및(and) ((샛별형 또는(or) 상승삼법형))을 만족하는 검색식 작성을 부탁드립니다. 나름 여러 예문을 참조해 노력해봤는데 잘 안돼 요청합니다. 감사합니다.
프로필 이미지
선도인
2025-07-17
188
글번호 192543
종목검색
답변완료

문의드립니다,

수고가 많으십니다. 1.data2 이동평균선 골든시 data1 A 금액매수 2.data2 이동평균선 골든크로스이후 data1 rsi oscilletor 매수신호시 매수함. 3.총투자금은 1백만원 이고 총10회나누어매수 매수후 1%상승시 투자되어진금액중20%매도식 2% 상승시 남은금액중 20%매도식 3%상승시 남은금액중20%매도식 4%상승시 남은금액중20%매도식 5%상승시남은금액중 20%매도식 4..data2 이동평균선 데드시 모든금액매도 많은폭우에 건강유의하시기 바랍니다
프로필 이미지
2685up
2025-07-17
189
글번호 192542
시스템
답변완료

부탁드립니다.

1> Plot1 부터 Plot5 까지 굵기10으로 만들 수 있게 색상도 변경할 수 있게 수식에 넣어 주세요 input : 기간(60),k(25); var : HH(0),LL(0); HH=highest(H,기간); LL=Lowest(L,기간); Plot1(HH,"상방돌파"); Plot2((HH-LL)*0.750+LL,"상빠른매매"); Plot3((HH-LL)*0.5+LL,"핵심선"); Plot4((HH-LL)*(K/100)+LL,"하빠른매매"); Plot1(LL,"하방돌파"); 2> 마디가 검은 굵은선 10의 두께로 지정하고 마디가와 마디가 중간선 빼고 녹색 분홍색 선 지워 주세요 input : 간격(2.5); var : cnt(0); Array : TL1[100](0),TL2[100](0),TL3[100](0),TL4[100](0); Array : TL5[100](0),TL6[100](0),TL7[100](0),TL8[100](0); Array : TX1[100](0),TX2[100](0),TX3[100](0),TX4[100](0); Array : TX5[100](0),TX6[100](0),TX7[100](0),TX8[100](0); if Index == 1 or Bdate != Bdate[1] Then { var1 = (Floor(DayOpen/간격)*간격)-100; For cnt = 0 to 99 { TL_Delete(TL1[cnt]); TL_Delete(TL2[cnt]); TL_Delete(TL3[cnt]); TL_Delete(TL4[cnt]); TL_Delete(TL5[cnt]); TL_Delete(TL6[cnt]); TL_Delete(TL7[cnt]); TL_Delete(TL8[cnt]); value11 = var1+간격*cnt; value12 = value11+(간격/8)*1; value13 = value11+(간격/8)*2; value14 = value11+(간격/8)*3; value15 = value11+(간격/8)*4; value16 = value11+(간격/8)*5; value17 = value11+(간격/8)*6; value18 = value11+(간격/8)*7; TL1[cnt] = TL_New(sDate,sTime,value11,NextBarSdate,NextBarStime,Value11); TL2[cnt] = TL_New(sDate,sTime,value12,NextBarSdate,NextBarStime,Value12); TL3[cnt] = TL_New(sDate,sTime,value13,NextBarSdate,NextBarStime,Value13); TL4[cnt] = TL_New(sDate,sTime,value14,NextBarSdate,NextBarStime,Value14); TL5[cnt] = TL_New(sDate,sTime,value15,NextBarSdate,NextBarStime,Value15); TL6[cnt] = TL_New(sDate,sTime,value16,NextBarSdate,NextBarStime,Value16); TL7[cnt] = TL_New(sDate,sTime,value17,NextBarSdate,NextBarStime,Value17); TL8[cnt] = TL_New(sDate,sTime,value18,NextBarSdate,NextBarStime,Value18); TL_SetExtLeft(TL1[cnt],true); TL_SetExtLeft(TL2[cnt],true); TL_SetExtLeft(TL3[cnt],true); TL_SetExtLeft(TL4[cnt],true); TL_SetExtLeft(TL5[cnt],true); TL_SetExtLeft(TL6[cnt],true); TL_SetExtLeft(TL7[cnt],true); TL_SetExtLeft(TL8[cnt],true); TL_SetExtRight(TL1[cnt],true); TL_SetExtRight(TL2[cnt],true); TL_SetExtRight(TL3[cnt],true); TL_SetExtRight(TL4[cnt],true); TL_SetExtRight(TL5[cnt],true); TL_SetExtRight(TL6[cnt],true); TL_SetExtRight(TL7[cnt],true); TL_SetExtRight(TL8[cnt],true); TL_SetSize(TL1[cnt],6); TL_SetSize(TL2[cnt],0); TL_SetSize(TL3[cnt],0); TL_SetSize(TL4[cnt],0); TL_SetSize(TL5[cnt],0); TL_SetSize(TL6[cnt],0); TL_SetSize(TL7[cnt],0); TL_SetSize(TL8[cnt],0); TL_SetStyle(TL1[cnt],0); TL_SetStyle(TL2[cnt],3); TL_SetStyle(TL3[cnt],0); TL_SetStyle(TL4[cnt],3); TL_SetStyle(TL5[cnt],2); TL_SetStyle(TL6[cnt],3); TL_SetStyle(TL7[cnt],0); TL_SetStyle(TL8[cnt],3); TL_SetColor(TL1[cnt], rgb(0, 0, 0)); TL_SetColor(TL2[cnt],rgb(242, 135, 192)); TL_SetColor(TL3[cnt],rgb(155, 217, 157)); TL_SetColor(TL4[cnt],rgb(242, 135, 192)); TL_SetColor(TL5[cnt], rgb(0, 0, 0)); TL_SetColor(TL6[cnt],rgb(242, 135, 192)); TL_SetColor(TL7[cnt],rgb(155, 217, 157)); TL_SetColor(TL8[cnt],rgb(242, 135, 192)); Text_Delete(TX1[cnt]); Text_Delete(TX2[cnt]); Text_Delete(TX3[cnt]); Text_Delete(TX4[cnt]); Text_Delete(TX5[cnt]); Text_Delete(TX6[cnt]); Text_Delete(TX7[cnt]); Text_Delete(TX8[cnt]); TX1[cnt] = Text_New(NextBarSdate,NextBarStime,value11," "+NumToStr(value11,2)); TX2[cnt] = Text_New(NextBarSdate,NextBarStime,value12," "+NumToStr(value12,2)); TX3[cnt] = Text_New(NextBarSdate,NextBarStime,value13," "+NumToStr(value13,2)); TX4[cnt] = Text_New(NextBarSdate,NextBarStime,value14," "+NumToStr(value14,2)); TX5[cnt] = Text_New(NextBarSdate,NextBarStime,value15," "+NumToStr(value15,2)); TX6[cnt] = Text_New(NextBarSdate,NextBarStime,value16," "+NumToStr(value16,2)); TX7[cnt] = Text_New(NextBarSdate,NextBarStime,value17," "+NumToStr(value17,2)); TX8[cnt] = Text_New(NextBarSdate,NextBarStime,value18," "+NumToStr(value18,2)); Text_SetStyle(TX1[cnt],0,1); Text_SetStyle(TX2[cnt],0,1); Text_SetStyle(TX3[cnt],0,1); Text_SetStyle(TX4[cnt],0,1); Text_SetStyle(TX5[cnt],0,1); Text_SetStyle(TX6[cnt],0,1); Text_SetStyle(TX7[cnt],0,1); Text_SetStyle(TX8[cnt],0,1); Text_SetSize(TX1[cnt],12); Text_SetSize(TX2[cnt],12); Text_SetSize(TX3[cnt],12); Text_SetSize(TX4[cnt],12); Text_SetSize(TX5[cnt],12); Text_SetSize(TX6[cnt],12); Text_SetSize(TX7[cnt],12); Text_SetSize(TX8[cnt],12); Text_SetColor(TX1[cnt], rgb(0, 0, 0)); Text_SetColor(TX2[cnt], rgb(245, 102, 200)); Text_SetColor(TX3[cnt],rgb(1, 198, 8)); Text_SetColor(TX4[cnt], rgb(245, 102, 200)); Text_SetColor(TX5[cnt],rgb(0, 0, 0)); Text_SetColor(TX6[cnt], rgb(245, 102, 200)); Text_SetColor(TX7[cnt],rgb(1, 198, 8)); Text_SetColor(TX8[cnt], rgb(245, 102, 200)); } } Else { For cnt = 0 to 99 { Text_SetLocation(TX1[cnt],NextBarSdate,NextBarStime,Text_GetValue(TX1[cnt])); Text_SetLocation(TX2[cnt],NextBarSdate,NextBarStime,Text_GetValue(TX2[cnt])); Text_SetLocation(TX3[cnt],NextBarSdate,NextBarStime,Text_GetValue(TX3[cnt])); Text_SetLocation(TX4[cnt],NextBarSdate,NextBarStime,Text_GetValue(TX4[cnt])); Text_SetLocation(TX5[cnt],NextBarSdate,NextBarStime,Text_GetValue(TX5[cnt])); Text_SetLocation(TX6[cnt],NextBarSdate,NextBarStime,Text_GetValue(TX6[cnt])); Text_SetLocation(TX7[cnt],NextBarSdate,NextBarStime,Text_GetValue(TX7[cnt])); Text_SetLocation(TX8[cnt],NextBarSdate,NextBarStime,Text_GetValue(TX8[cnt])); } }
프로필 이미지
어떤하루
2025-07-17
270
글번호 192538
지표
답변완료

수식수정요청

안녕하세요 늘 도움 감사드립니다. 아래의 수식에 당일 07:15 분 고가 저가 에 수치와 선을 나타나게 하고 싶은데..오류가 나와 수정 부탁드려요 Vars: myHigh(0), myLow(0), flagCaptured(false), lastDate(0); If Date <> lastDate Then Begin lastDate = Date; flagCaptured = false; End; If (Time = 715) And (flagCaptured = false) Then Begin myHigh = High; myLow = Low; flagCaptured = true; End; Plot1(myHigh, "07:15 고가"); SetPlotColor(1, Green); Plot2(myLow, "07:15 저가"); SetPlotColor(2, Red);
프로필 이미지
알리섬
2025-07-17
206
글번호 192535
지표
답변완료

부탁드립니다

수고하십니다 input : ratio(3); 조건up = L>H[2]*(1+ratio/100)&& L<H[1] && L[1]<=H[2]; 조건dn = L[2]>H *(1+ratio/100)&& L[2]<=H[1] && L[1]<H ; 조건up 박스중심 점선 조건dn 박스중심 점선 현재가가 조건up 박스돌파시 박스선 삭제 현재가가 조건dn 박스돌파시 박스선 삭제 (box_new)함수를 사용하여 수식부탁드립니다.
프로필 이미지
파생돌이
2025-07-16
248
글번호 192534
지표
답변완료

93476관련입니다

93476번에서 드린 질문이 (하이킨아시 일봉이 일목균형표 26일기준선을 돌파하면서 RSI(20)이 50선을 돌파하는 종목 검색식을 만들려는데 도움부탁드립니다) 이고, 그 답은 아래 첨부와 같읍니다. 일봉에서 잘 만족스럽게 검색이 됩니다. 이것은 0봉전으로 되어 있는데, 이것을 30분 분봉에서 검색하기 위해 1봉전에 "26기준선돌파+rsi(20)이 50돌파+1봉전 ~ 5봉전 rsi(20)은 49.9"이하 로 수정하고 싶습니다. ================ 첨 부 ================================================== input : P(20); var : xClose(0),xOpen(0),xHigh(0),xLow(0); var : 기준선(0),R(0); Var : Counter(0), DownAmt(0), UpAmt(0), UpSum(0), DownSum(0), UpAvg(0), DownAvg(0); #Heiken Ashi 시고저종 if index == 0 then { xClose = (O+H+L+C)/4; xOpen = open; xHigh = MaxList( high, xOpen, xClose); xLow = MinList( low, xOpen,xClose); } else { xClose = (O+H+L+C)/4; xOpen = (xOpen [1] + xClose [1])/2 ; xHigh = MaxList(High, xOpen, xClose) ; xLow = MinList(Low, xOpen, xClose) ; } 기준선 = (Highest(xHigh, 26) + Lowest(xLow, 26)) / 2; If CurrentBar == 1 AND P > 0 Then Begin UpSum = 0; DownSum = 0; For Counter = 0 To P - 1 Begin UpAmt = xClose[Counter] - xClose[Counter+1]; If UpAmt >= 0 Then DownAmt = 0; Else Begin DownAmt = -UpAmt; UpAmt = 0; End; UpSum = UpSum + UpAmt; DownSum = DownSum + DownAmt; End; UpAvg = UpSum / P; DownAvg = DownSum / P; End Else If CurrentBar > 1 AND P > 0 Then Begin UpAmt = xClose[0] - xClose[1]; If UpAmt >= 0 Then DownAmt = 0; Else Begin DownAmt = -UpAmt; UpAmt = 0; End; UpAvg = (UpAvg[1] * (P - 1) + UpAmt) / P; DownAvg = (DownAvg[1] * (P - 1) + DownAmt) / P; End; If UpAvg + DownAvg <> 0 Then R = 100 * UpAvg / (UpAvg + DownAvg); Else R = 0; if CrossUp(xClose,기준선) and CrossUp(R,50) Then Find(1);
프로필 이미지
ksks
2025-07-16
270
글번호 192533
종목검색
답변완료

추세선의 높이 구하는 수식 부탁드립니다

추세선의 높이를 구하는 수식 부탁드립니다 상승추세는 빨강색 하락추세는 파랑색 ============================================= input : Period(35),선두께(2),기준(-10),p(5); Var:상승색(Turquoise), 하락색(Turquoise),Vpower(0),mav(0); Var:j(0),T(0); Var: date11(0),date12(0),time11(0),time12(0),TL1(0),TL(0),tl9(0), date21(0),date22(0),time21(0),time22(0), date31(0),date32(0),time31(0),time32(0),tx(0),tx1(0),tl4(0); Array:HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](0); Array:r[7](0),fr[7](0),TL2[7](0),TL3[7](0),TX2[7](0),TX3[7](0); Plot1(0); For j = 0 To 19 { HiBar[j] = HiBar[j] + 1; LoBar[j] = LoBar[j] + 1; } Vpower = upVol/(upVol+downVol)*100-50; mav = ma(Vpower,p); if 기준 < mav Then T = 1; if 기준 > mav Then T = -1; If T == -1 Then { If T[1] != -1 Then { For j = 18 DownTo 0 { LoVal[j+1] = LoVal[j]; LoBar[j+1] = LoBar[j]; } LoVal[0] = L; LoBar[0] = 0; date11 = date[HiBar[0]]; time11 = stime[HiBar[0]]; Value11 = HiVal[0]; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; TL_Delete(tl); TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); TL1 = TL_New(date11,time11,Value11,date12,time12,Value12); TL_SetColor(TL1,하락색); date21 = date[HiBar[0]]; time21 = stime[HiBar[0]]; date22 = date[0]; time22 = stime[0]; for j = 0 to 6 { fr[j] = LoVal[1] + ((HiVal[0] - LoVal[1]) * r[j]); } } If LoVal[0] > L Then { LoVal[0] = L; LoBar[0] = 0; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; TL_SetEnd(TL1, date12,time12,Value12); date22 = date[0]; time22 = stime[0]; TL_Delete(tl); TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); } } If T == 1 Then { If T[1] != 1 Then { For j = 18 DownTo 0 { HiVal[j+1] = HiVal[j]; HiBar[j+1] = HiBar[j]; } HiVal[0] = H; HiBar[0] = 0; date11 = date[LoBar[0]]; time11 = stime[LoBar[0]]; Value11 = LoVal[0]; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; TL_Delete(tl); TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); TL1 = TL_New(date11,time11,Value11,date12,time12,Value12); TL_SetColor(TL1,상승색); date31 = date[LoBar[0]]; time31 = stime[LoBar[0]]; date32 = date[0]; time32 = stime[0]; for j = 0 to 5 { fr[j] = LoVal[0] + ((HiVal[1] - LoVal[0]) * r[j]); } } If HiVal[0] < H Then { HiVal[0] = H; HiBar[0] = 0; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; TL_SetEnd(TL1, date12,time12,Value12); date32 = date[0]; time32 = stime[0]; TL_Delete(tl); TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); } } TL_SetSize(TL1,선두께); TL_SetDrawMode(TL1,0);
프로필 이미지
팔보채
2025-07-16
254
글번호 192532
지표
답변완료

지표부탁드립니다.

시가총액1조이상 종목 일봉상 볼린저밴드240 상단보다 높고 전일고가돌파 시 1분봉에서 검색될수 있는 검색식좀 부탁드립니다. 항상 감사합니다. 좋은하루 되세요
프로필 이미지
mizno
2025-07-16
266
글번호 192525
종목검색
답변완료

수식을 부탁드립니다

늘 친절히 답해 주셔서 감사를 드립니다. 1분,5분,10분 모두 ADX 상승, +DI>-DI일 때 매수하고, 1분,5분 에서 ADX가 하락하면 매수 청산, 그리고 반대의 경우는 매도와 매도 청산하는 수식을 작성하고자 합니다.넓으신 마음으로 이해해 주시면 감사하겠습니다. 늘 건강하시기를 기원합니다.
프로필 이미지
장보고153
2025-07-16
251
글번호 192524
시스템