커뮤니티

예스랭귀지 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%
프로필 이미지
ksks
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
프로필 이미지
onlypsn
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
지표