커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4270
글번호 230811
답변완료
수식문의
이격도표현하는 방법을 또 잊었는데요, 다음 조건수식을 문의드립니다.C>200EMA시 시가와 200EMA : 0% ~ 5% orC<200EMA시 종가와 200EMA : -5% ~ 0%
2026-05-08
64
글번호 231957
답변완료
종목검색 오류
안녕하세요.항상 칠전한 답변 너무 감사드립니다.아래코드를 5월7일을 0봉전으로 수행했을때, 삼성증권이 조건에 따라 검색되지 않아야 함에도 불구하고 검색이 진행되어 문의드립니다.condition5 때문에 검색대상에서 배제 되어야 하거든요.. 당최이유를 모르겠습니다..input : 기준봉대금조건(60000000000), 기준봉상승률조건(15);// ==========================// 변수 선언// ==========================var : i(0), idx(0);var : 기준봉고가(0);var : MA5Dist0(0);var : MinMA5Dist(99999999);var : UpperTail_BodySize(0);var : LowerTail(0),Condition5(False);// ==========================// 기준봉 조건// ==========================Condition1 = (Money >= 기준봉대금조건) and (C >= C[1] * (1 + 기준봉상승률조건 / 100));// ==========================// 기준봉 탐색// ==========================idx = 0;for i = 1 to 9{ if Condition1[i] and idx == 0 then idx = i;}// ==========================// 기준봉 이후 조건// ==========================// 기준봉이 1봉전인 경우 제외 (idx >= 2)if idx >= 2 then{ 기준봉고가 = H[idx]; // -------------------------------- // Condition2: 기준봉 이후 고가 돌파 // -------------------------------- Condition2 = Highest(H, idx) > 기준봉고가; // -------------------------------- // Condition3: 현재봉이 5일선 위 // -------------------------------- Condition3 = C > ma(c,5); // -------------------------------- // Condition4: 현재봉이 기준봉 이후 중 // 5일선과 가장 근접 (저가 기준) // -------------------------------- MA5Dist0 = AbsValue(L - ma(c,5)); MinMA5Dist = 99999999; for i = 0 to idx - 1 { if AbsValue(L[i] - ma(c,5)[i]) < MinMA5Dist then MinMA5Dist = AbsValue(L[i] - ma(c,5)[i]); } Condition4 = MA5Dist0 <= MinMA5Dist; // -------------------------------- // Condition5: 아래꼬리 > 나머지 부분 // -------------------------------- UpperTail_BodySize = H - MinList(C,O); LowerTail = MinList(C,O) - L; Condition5 = LowerTail > UpperTail_BodySize; // -------------------------------- // 최종 신호 // -------------------------------- if Condition2 and Condition3 and Condition4 and Condition5 then Find(1);}
2026-05-08
67
글번호 231956
답변완료
수식 문의
안녕하세요?1. 예컨대, 5분봉 차트에 적용하면 봉이 완성되는 5분마다1번씩만 쓰고 싶은데.아래처럼 하니까 계속 마구 써지네요.수식 정정 부탁드립니다.if NextBarOpen > 0 Then{ Print("D:\\문자Test\\1\\abc.txt","%s", numToStr(Date,0) + "|" + numToStr(Time,0) + "|D1=" + NumToStr(Data1(c), 6) + "|D2=" + NumToStr(Data2(c), 6) + "|D3=" + NumToStr(Data3(c), 6) + "|D4=" + NumToStr(Data4(c), 6) + "|D5=" + NumToStr(Data5(c), 6) + "|D6=" + NumToStr(Data6(c), 6) + "|D7=" + NumToStr(Data7(c), 6) );}2.예스언어에서 텍스트 파일 "통째로 덮어쓰기" 함수 이름은? (예: FileWrite, WriteToFile, FileAppend 등 — 정확히 무엇이 가능한가요?)3. 5분봉 (미니)코스피200선물 OHLCV와 KP200선물외인순매수금액을 CSV 화일 등으로 내보내는 방법이 있나요?있다면 어떻게 하는지 궁금합니다.감사합니다.
2026-05-08
65
글번호 231955
답변완료
종목검색식 요청드립니다.
아래 키움신호가 발생된 종목을 검색하는 검색식을 만들고 싶습니다. 도움 부탁드립니다.* 키움신호장기=MA(C,60);중기=MA(C,20);단기=MA(C,5);추세조건 = 장기 < 중기 && 중기 < 단기;전환=(highest(high,9)+lowest(low,9))/2;기준=(highest(high,26)+lowest(low,26))/2;Bu=BBandsUp(120,2);행복=(Highest(Bu,52)+Lowest(Bu,52))/2;A1=eavg(C,120)+stdev((C+H+L)/3,120);타이밍=crossup(min(전환,기준),min(행복,A1))&& crossup(min(전환,기준),행복);추세조건&& 타이밍&& V > MA(V,20)*1.5&& C > C(1)*1.2
2026-05-08
80
글번호 231944
답변완료
지표식 부탁합니다
안녕하십니까수고가 많으십니다글번호231924 관련입니다 지표식 수정 부탁합니다Input : StartTime(90000),분(90);var : D1(0),TM(0),TF(0),OO(Nan);If (sdate!=sDate[1] and sTime>=StartTime) Then{D1 = sdate;}If D1>0 then{ If sdate==D1 Then TM=TimeToMinutes(stime); Else TM=TimeToMinutes(stime)+1440; TF = TM%분; If Bdate!=Bdate[1] or (Bdate == Bdate[1] and 분 > 1 and TF < TF[1]) or (Bdate == Bdate[1] and 분 > 1 and TM >= TM[1]+분) or (Bdate == Bdate[1] and 분 == 1 and TM > TM[1]) Then { OO = Open; if OO < OO[1] Then OO = min(Open,Close); Else OO = max(Open,Close); } Plot1(OO, "G", Green);}위 식을 수정하고 싶습니다양봉일 경우 선이 내려올 때 시가로, 선이 올라갈 때 종가로 선을 긋고음봉일 경우 선이 내려올 때나 올라갈 때나 종가로 선을 그을 수 있도록 수정하여 주시면 고맙겠습니다
2026-05-07
76
글번호 231943
답변완료
수식 변환 부탁드립니다.
HC = Highest(c,30);NewC=valuewhen(1,c>HC(1),c);Box1=highest(c,28)<highest(c,29);Top=valuewhen(1,Barssince(c>HC(1))==(28) and Box1,NewC);Top위 지표를 당일 종가가 상향 돌파하는 종목을 예스랭귀지로 종목검색수식을 만들려고 하는데 Valuewhen 함수와 Barssince 를 어떻게 표현해야 할지 모르겠습니다.부탁드립니다.
2026-05-07
78
글번호 231942
답변완료
문의 합니다...^^*
안녕하세요....아래 수식은 예스 종목검색 수식입니다...아래 수식에서 조건을 추가하기 위해서 문의 드립니다..조건추가는 종목검색 되는 위치가 1분봉상 피봇1차저항선과 피봇2차저항선 사이에서 출현 또는 1분봉상 당일시가 근처에서 출현하는 조건으로 아래수식을수정부탁드립니다...var : BB(0),EV(0);BB=BollBandUp(20,2);EV=EnvelopeUp(20,3);if crossup(BB,EV) and C>BB and C>EV Then Find(1);
2026-05-07
68
글번호 231940
답변완료
수식 부탁합니다
스토캐스틱 (25,6,6) 골든크로스 발생단 슈퍼트렌드 발생 현재 기준 30일 이내에 있어야 하고 슈퍼트렌드 발생한 후 첫번째 스토캐스틱(25,6,6) 골든크로스 발생한 종목 검색식 부탁합니다ㅣ
2026-05-07
55
글번호 231938
답변완료
문의 드립니다
Input:length(10),종가사용여부(0),파동선두께(2),수치표시(1); Var:j(0),jj(0),HH(0),LL(0),최종고가(0),최종저가(0),최종꼭지점(""),처리구분(""), TL1(0),Text1(0),text2(0),TL2(0); Array:고[10,4](0),저[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime #==========================================# HH = IFF(종가사용여부==1,C,H); LL = IFF(종가사용여부==1,C,L); If Index == 0 Then { 고[1,1] = HH; 저[1,1] = LL; } Condition1 = Highest(HH,length) == HH and 최종고가 <> HH; Condition2 = Lowest (LL,length) == LL and 최종저가 <> LL;처리구분 = "";If Condition1 and Condition2 Then // 기간고점과 기간저점 동시 발생{ If 최종꼭지점 == "저점" Then { If 저[1,1] > LL Then 처리구분 = "저점처리"; Else 처리구분 = "고점처리"; } Else If 최종꼭지점 == "고점" Then { If 고[1,1] < HH Then 처리구분 = "고점처리"; Else 처리구분 = "저점처리"; } }Else If Condition1 Then 처리구분 = "고점처리";Else If Condition2 Then 처리구분 = "저점처리"; #==========================================#If 처리구분 == "고점처리" Then { 최종고가 = HH; // 신규고점을 체크하기 위해 저장 If 최종꼭지점 == "저점" Then { For j = 10 DownTo 2 { For jj = 1 To 4 { 고[j,jj] = 고[j-1,jj]; } } 고[1,1] = HH; 고[1,2] = Index; 고[1,3] = sDate; 고[1,4] = sTime; // TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]); var1 = 고[2,1]-저[1,1]; // TL2 = TL_New(저[1,3],저[1,4],저[1,1]-var1,sDate,sTime,저[1,1]-var1); If 수치표시 == 1 Then { Text1 = Text_New(고[1,3],고[1,4],고[1,1],NumToStr(고[1,1],2)); Text_SetStyle(Text1, 2, 1); //Text2 = Text_New(고[1,3],고[1,4],고[1,1],NumToStr(고[1,1]-저[1,1],2)+NewLine); Text_SetStyle(Text2, 2, 1); Text_SetColor(text2,RED); Text_Setbold(text1,1); Text_SetSize(text2,13); } TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,GREEN); TL_SetSize(TL2,파동선두께); TL_SetColor(TL2,BLUE); } Else If 고[1,1] < HH Then // 1번 고점보다 높은 고가 출현 { 고[1,1] = HH; 고[1,2] = Index; 고[1,3] = sDate; 고[1,4] = sTime; TL_SetEnd(TL1,고[1,3],고[1,4],고[1,1]); TL_SetEnd(TL2,고[1,3],고[1,4],저[1,1]-var1); // 시작점은 변동없고 끝점의 위치가 현재 봉으로 연장된 것임 If 수치표시 == 1 Then { Text_SetLocation(Text1,고[1,3],고[1,4],고[1,1]); Text_SetColor(text1,Red); Text_SetString(Text1,NumToStr(고[1,1],2)); Text_SetLocation(Text2,고[1,3],고[1,4],고[1,1]); Text_SetColor(text2,Red); Text_Setbold(text1,1);Text_SetSize(text2,12); Text_SetString(Text2,NumToStr(고[1,1]-저[1,1],2)+NewLine); } } 최종꼭지점 = "고점"; } #==========================================#If 처리구분 == "저점처리" Then { 최종저가 = LL; If 최종꼭지점 == "고점" then { For j = 10 DownTo 2 { For jj = 1 To 4 { 저[j,jj] = 저[j-1,jj]; } } 저[1,1] = LL; 저[1,2] = Index; 저[1,3] = sDate; 저[1,4] = sTime; // TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]); var1 = 고[1,1]-저[2,1]; // TL2 = TL_New(고[1,3],고[1,4],고[1,1]+var1,sDate,sTime,고[1,1]+var1); If 수치표시 == 1 Then { Text1 = Text_New(저[1,3],저[1,4],저[1,1],NumToStr(저[1,1],2)); Text_SetStyle(Text1, 2, 0); // Text2 = Text_New(저[1,3],저[1,4],저[1,1],NewLine+NumToStr(저[1,1]-고[1,1],2)); Text_SetStyle(Text2, 2, -1); Text_SetColor(text2,Black); Text_Setbold(text1,1);Text_SetSize(text2,13); } TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,GREEN); TL_SetSize(TL2,파동선두께); TL_SetColor(TL2,Red); } Else If 저[1,1] > LL then { 저[1,1] = LL; 저[1,2] = Index; 저[1,3] = sDate; 저[1,4] = sTime; TL_SetEnd(TL1,저[1,3],저[1,4],저[1,1]); TL_SetEnd(TL2,저[1,3],저[1,4],고[1,1]+var1); If 수치표시 == 1 Then { Text_SetLocation(Text1,저[1,3],저[1,4],저[1,1]); Text_SetColor(text1,Black); Text_SetString(Text1,NumToStr(저[1,1],2)); Text_SetLocation(Text2,저[1,3],저[1,4],저[1,1]); Text_SetColor(text2,Black); Text_Setbold(text1,1);Text_SetSize(text2,12); Text_SetString(Text2,NewLine+NumToStr(저[1,1]-고[1,1],2)); } } 최종꼭지점 = "저점"; } -------------위수식에서 고점, 저점이 텍스트로 표시되면 그 지점에 세로선이 나오게 하고 싶은데 가능할까요?고점, 저점이 계속 갱신되면 갱신되는 대로 세로선이 나오다가 다시 갱신되지 않으면 최종 세로선이 그어지게 합니다고점세로선 과 저점 세로선 색상은 구별가능하게 지정할수 있음 좋겠습니다감사합니다
2026-05-07
79
글번호 231937