커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

문의합니다

파워종목 검색식에서 실시간 분봉검색식을 하고있읍니다. 시간되면 자동으로 검색식을 할수있는 코딩을할수있느지요. 예를들면 홀수분 에서 자동으로검색하여 조건에맞는 종목이 파워종목창에 올라와서 확인이가능한지요. 가능하면 밸소리도 가능한지요. 가능하다면 랭귀지수식좀 부탁합니다. 주석처리도 부탁합니다.
프로필 이미지
조만호
2019-01-14
166
글번호 125267
종목검색
답변완료

수식 부탁드립니다.

매수 매도 진입은 TRIX 0선으로 하고 청산은 두 선 교체신호에서 하고자 합니다. 원하는 진입식 입니다. 청산식은 아래에 있습니다. 접목 부탁드립니다. 매번 감사드립니다. 수고하세요. Input : Period(5); value1 = TRIX(Period); # 매수/매도청산 If CrossUP(value1, 0) Then { Buy(); } # 매도/매수청산 If CrossDown(value1, 0) Then { Sell(); } 원하는 청산식 Input : Period(5), sigPeriod(3); value1 = TRIX(Period); value2 = ema(value1, sigPeriod); # 매수/매도청산 If CrossUP(value1, value2) Then { Buy(); } # 매도/매수청산 If CrossDown(value1, value2) Then { ExitLong(); }
프로필 이미지
선물대장
2019-01-14
146
글번호 125266
시스템
답변완료

행복; 지표식 작성 바랍니다

한국의 금융산업 발전을 위해 불철주야 애쓰시는 귀하의 노고를 높이 평가합니다 지표식 관련입니다 << 아래 >>의 지표식은 분봉 차트에서 일봉의 볼린져밴드를 그리는 지표식 입니다 ==============<< 아래 시작 >>============================================ # 분봉에서 일봉 볼린져밴드 계산 시작 input : dayPeriod(20),dayDv(2); var : daysum(0),daycnt(0),dayma(0),daySumSqrt(0),dayStdv(0); var : dayBBup(0),dayBBdn(0),dayCounter(0); # 일봉 이동평균 계산 daysum = 0; for daycnt = 0 to dayPeriod-1{ daysum = daysum + DayClose(daycnt); } dayma = daysum/dayPeriod; #표준편차 계산 If DayClose(dayPeriod) != 0 Then { daySumSqrt = 0; For dayCounter = 0 To dayPeriod - 1 { daySumSqrt = daySumSqrt + (DayClose(dayCounter) - dayma)^2; } dayStdv = SquareRoot(daySumSqrt / dayPeriod); } Else dayStdv = 0; # 일봉 볼린져밴드 계산 dayBBup = dayma + (dayDv * dayStdv); dayBBdn = dayma - (dayDv * dayStdv); plot1(dayBBup ,"상단"); plot2(dayma,"중단"); plot3(dayBBdn,"하단"); ==============<< 아래 끝 >>============================================== < 질문1 > - 분봉 차트에서 주봉의 볼린져밴드를 그리는 지표식 작성 바랍니다 < 질문2 > - 분봉 차트에서 월봉의 볼린져밴드를 그리는 지표식 작성 바랍니다 < 질문3 > - 10분봉 차트에서 140분봉의 볼린져밴드를 그리는 지표식 작성바랍니다 수고하십시요^^
프로필 이미지
행복한가방
2019-01-14
186
글번호 125250
지표

회원 님에 의해서 삭제되었습니다.

프로필 이미지
회원
2019-01-14
0
글번호 125249
지표
답변완료

수식 부탁드립니다.

아래 식에서 이평5 이평20 정배열 상태일 경우 전일 고가 돌파 시 매수 진입 역배열 상태일 경우 전일 저가 돌파 시 매도 진입 부탁드립니다. 두 가지를 접목 하고 싶은데 잘 모를겠습니다. 부탁드립니다. IF H[1] < C Then buy(); IF L[1] > C Then Exitlong(); IF L[1] > C Then sell(); IF H[1] < C Then ExitShort();
프로필 이미지
선물대장
2019-01-14
148
글번호 125240
시스템
답변완료

수식 요청 드립이다.

안녕하세요. 아래 수식 당일목표수익 30틱 달성시 당일청산에서, 30틱 이상 달성한 이후 부터는 현재 매수일 경우 현재봉의 종가가 10이평을 하향 돌파하하거나 or 마지막 진입후 최고가에서 10% 하락시 당일청산 수식으로 변경요청 드립이다. 감사합니다 //---------------------------------------------------------------------------------- Input : 익절(15),손절(10),당일목표수익(30),당일목표손실(20); input : 시작시간1(101500),종료시간1(125500),시작시간2(140000),종료시간2(151500); Input : Period(12), sigPeriod(9); var : Tcond(false); Var : N1(0),dayPl(0),당일수익(0),당일손실(0),Xcond(false); 당일수익 = PriceScale*당일목표수익; 당일손실 = PriceScale*당일목표손실; daypl = NetProfit-N1; if (sdate != sdate[1] and stime >= 시작시간1) or (sdate == sdate[1] and stime >= 시작시간1 and stime[1] < 시작시간1) Then { Tcond = true; Xcond = false; N1 = NetProfit; } if (sdate != sdate[1] and stime >= 종료시간1) or (sdate == sdate[1] and stime >= 종료시간1 and stime[1] < 종료시간1) Then { Tcond = false; if MarketPosition == 1 Then ExitLong("bx1"); if MarketPosition == -1 Then ExitShort("sx1"); } if (sdate != sdate[1] and stime >= 시작시간2) or (sdate == sdate[1] and stime >= 시작시간2 and stime[1] < 시작시간2) Then { Tcond = true; } if (sdate != sdate[1] and stime >= 종료시간2) or (sdate == sdate[1] and stime >= 종료시간2 and stime[1] < 종료시간2) Then { Tcond = false; if MarketPosition == 1 Then ExitLong("bx2"); if MarketPosition == -1 Then ExitShort("sx2"); } if TotalTrades > TotalTrades[1] then { if (IsExitName("dbp",1) == true or IsExitName("dbl",1) == true or IsExitName("dsp",1) == true or IsExitName("dsl",1) == true) then Xcond = true; if daypl >= 당일수익 or daypl <= -당일손실 Then Xcond = true; } value1 = TRIX(Period); value2 = ema(value1, sigPeriod); if Tcond == true and Xcond == false then { If CrossUP(value1, value2) Then Buy("b"); If CrossDown(value1, value2) Then Sell("s"); } if MarketPosition == 1 and Xcond == false then { ExitLong("dbp",atlimit,EntryPrice+((당일수익-daypl)/CurrentContracts)); ExitLong("dbl",AtStop,EntryPrice-((당일손실+daypl)/CurrentContracts)); ExitLong("bp",Atlimit,EntryPrice+PriceScale*익절); ExitLong("bl",AtStop,EntryPrice-PriceScale*손절); } if MarketPosition == -1 and Xcond == false then { ExitShort("dsp",atlimit,EntryPrice-((당일수익-daypl)/CurrentContracts)); ExitShort("dsl",AtStop,EntryPrice+((당일손실+daypl)/CurrentContracts)); ExitShort("sp",Atlimit,EntryPrice-PriceScale*익절); ExitShort("sl",AtStop,EntryPrice+PriceScale*손절); } //----------------------------------------------------------------------------------
프로필 이미지
dandy
2019-01-14
161
글번호 125238
시스템
답변완료

질문드립니다.

안녕하세요. 아래로직과 같이 종목검색시 별개의 종목들이 검색됩니다. 현재 condition99를 만족하고 거래대금이 50억 이상이고 시가가 전일종가의 4%미만이며, 당일시가대비 고가가5%상승한 종목을 검색하는것인데, 금일 '유니크'와 같이 전혀무관한 종목이 검색됩니다. 위 조건에 부합하는 종목만 검색이 되면 좋겠습니다... Var:barCnt(10); Var:j(0),turnPntBit(""),TL1(0),TL2(0); Array:valArr[10](0),barArr[10](0),turnPntArr[10](""); var : count1(0),count2(0), idx(0); if sDate != sDate[1] Then { Condition99 = false; count1 = 0; count2 = 0; Value1 = 0; Value2 = 0; } For j = 0 To 9 { barArr[j] = barArr[j] + 1; } Condition1 = Highest(H,barCnt)[barCnt+1] <= H[barCnt] and H[barCnt] > Highest(H,barCnt); Condition2 = Lowest(L,barCnt)[barCnt+1] >= L[barCnt] and L[barCnt] < Lowest(L,barCnt); turnPntBit = ""; If Condition1 and Condition2 Then { If Max(valArr[1],valArr[2]) < H[barCnt] and Min(valArr[1],valArr[2]) > L[barCnt] Then turnPntBit = "HiLo"; Else If Max(valArr[1],valArr[2]) < H[barCnt] Then turnPntBit = "Hi"; Else If Min(valArr[1],valArr[2]) > L[barCnt] Then turnPntBit = "Lo"; Else If turnPntArr[1] == "Hi" Then turnPntBit = "Lo"; Else If turnPntArr[1] == "Lo" Then turnPntBit = "Hi"; } Else If Condition1 Then turnPntBit = "Hi"; Else If Condition2 Then turnPntBit = "Lo"; If turnPntBit <> "" Then { If turnPntBit == "HiLo" Then { valArr[1] = IFF(turnPntArr[1] == "Hi",H[barCnt],L[barCnt]); barArr[1] = barCnt; TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]); If turnPntArr[1] == "Hi" Then turnPntBit = "Lo"; Else turnPntBit = "Hi"; } If turnPntBit <> turnPntArr[1] Then { for j = 8 downto 1 { valArr[j+1] = valArr[j]; barArr[j+1] = barArr[j]; turnPntArr[j+1] = turnPntArr[j]; } } If turnPntBit <> turnPntArr[1] or (turnPntBit == turnPntArr[1] and ((turnPntBit == "Hi" and valArr[1] < H[barCnt]) or (turnPntBit == "Lo" and valArr[1] > L[barCnt]))) Then { valArr[1] = IFF(turnPntBit == "Hi",H[barCnt],L[barCnt]); barArr[1] = barCnt; turnPntArr[1] = turnPntBit; If turnPntArr[1][1] <> turnPntArr[1][0] Then { if Condition99 == false and turnPntBit == "Hi" Then { Condition99 = true; value99 = valArr[1]; } } Else { } } } Var : Per2(80); VAR : RR(0), AA(0); RR = (DayOpen-Value99); AA = (value99-DayOpen); Var3 = (DayOpen-RR*(Per2/100)); //당일 고가선과 시가선의 50%선(중간값) 계산값은 = Var3 If sDate != sDate[1] Then{ idx = 0; } Input : 거래대금(500000000); //5억 if Condition99 == false and C > O Then Value1 = Value1+Money; If Condition99 == True and C <= O Then{ Value2 = Value2+Money; } If Condition99 == True Then{ if Value1 >= 거래대금 and DayOpen <= DayClose(1)*1.04 and DayHigh >= DayOpen*1.05 and (Value1/2) > Value2 Then Find(1); }
프로필 이미지
stockric
2019-01-14
189
글번호 125236
지표
답변완료

문의 드립니다.

도움 주심에 감사 드립니다. 다음 수식에서 기준일이 지정된것에 지정시분을 추가로 부탁 드립니다. Input:length(10),기준일(20190108),파동선두께(2); Var:j(0),jj(0),jjj(0),최종고가(0),최종저가(0),최종변곡점(""),처리구분(""), TL1(0); Array:고[5,4](0),저[5,4](0), // 1:가격, 2:Index, 3:sDate, 4:sTime 역사적고점[5](0),역사적저점[5](0); // 1:가격, 2:Index, 3:sDate, 4:sTime #==========================================# If Index == 0 Then { 고[1,1] = H; 저[1,1] = L; } Condition1 = Highest(H,length) == H and 최종고가 <> H; Condition2 = Lowest (L,length) == L and 최종저가 <> L; 처리구분 = ""; If Condition1 and Condition2 Then // 기간고점과 기간저점 동시 발생 { If 최종변곡점 == "저점" Then 처리구분 = "고점처리"; // 저 - 고 순으로 처리 Else 처리구분 = "저점처리"; // 고 - 저 순으로 처리 } Else If Condition1 Then 처리구분 = "고점처리"; Else If Condition2 Then 처리구분 = "저점처리"; #==========================================# If 처리구분 == "고점처리" Then { 최종고가 = H; // 신규고점을 체크하기 위해 저장 If 최종변곡점 == "저점" Then { For j = 5 DownTo 2 { For jj = 1 To 4 { 고[j,jj] = 고[j-1,jj]; } } 고[1,1] = H; 고[1,2] = Index; 고[1,3] = sDate; 고[1,4] = sTime; //TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]); TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,GREEN); } Else If 고[1,1] < H Then // 1번 고점보다 높은 고가 출현 { 고[1,1] = H; 고[1,2] = Index; 고[1,3] = sDate; 고[1,4] = sTime; TL_SetEnd(TL1,고[1,3],고[1,4],고[1,1]); } If 기준일 <= Date and 역사적고점[1] < 고[1,1] Then { For jjj = 1 To 4 // 1:가격, 2:Index, 3:sDate, 4:sTime { 역사적고점[jjj] = 고[1,jjj]; 역사적저점[jjj] = 0; // 역사적 고점 초기화 } } 최종변곡점 = "고점"; } #==========================================# If 처리구분 == "저점처리" Then { 최종저가 = L; If 최종변곡점 == "고점" then { For j = 5 DownTo 2 { For jj = 1 To 4 { 저[j,jj] = 저[j-1,jj]; } } 저[1,1] = L; 저[1,2] = Index; 저[1,3] = sDate; 저[1,4] = sTime; //TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]); TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,GREEN); } Else If 저[1,1] > L then { 저[1,1] = L; 저[1,3] = sDate; 저[1,4] = sTime; 저[1,2] = Index; TL_SetEnd(TL1,저[1,3],저[1,4],저[1,1]); } If 기준일 <= Date and ( 역사적저점[1] > 저[1,1] or 역사적저점[1] == 0 ) Then { For jjj = 1 To 4 { 역사적저점[jjj] = 저[1,jjj]; } } 최종변곡점 = "저점"; } #==========================================# Var:기울기(0); Array:fr[7,4](0); // 1:비율, 2:값, 3:라인번호, 4:텍스트번호 If Index == 0 Then { fr[1,1] = 0; fr[2,1] = 0.236; fr[3,1] = 0.382; fr[4,1] = 0.50; fr[5,1] = 0.618; fr[6,1] = 0.764; fr[7,1] = 1; } If 역사적고점[1] > 0 and 역사적저점[1] > 0 Then { If 역사적고점[1][1] != 역사적고점[1] or 역사적저점[1][1] != 역사적저점[1] Then { 기울기 = (역사적고점[1] - 역사적저점[1]) / (역사적고점[2] - 역사적저점[2]); for j = 1 to 7 { If fr[j,3] > 0 Then TL_Delete(fr[j,3]); // 기존의 라인은 지우고 fr[j,2] = 역사적고점[1] + 기울기 * fr[j,1] * (index - 역사적고점[2]) ; // 피보나치 비율을 곱해서 계산 fr[j,3] = TL_New(역사적고점[3],역사적고점[4],역사적고점[1],sDate,sTime,fr[j,2]); // 라인을 생성 } } Else { for j = 1 to 7 { fr[j,2] = 역사적고점[1] + 기울기 * fr[j,1] * (index - 역사적고점[2]); TL_SetEnd(fr[j,3],sDate,sTime,fr[j,2]); } } } Text_Delete(var1); var1 = Text_New(sdate,stime,fr[1,2],NumToStr(fr[1,1]*100,1)+"% : "+NumToStr(fr[1,2],2)); Text_Delete(var2); var2 = Text_New(sdate,stime,fr[2,2],NumToStr(fr[2,1]*100,1)+"% : "+NumToStr(fr[2,2],2)); Text_Delete(var3); var3 = Text_New(sdate,stime,fr[3,2],NumToStr(fr[3,1]*100,1)+"% : "+NumToStr(fr[3,2],2)); Text_Delete(var4); var4 = Text_New(sdate,stime,fr[4,2],NumToStr(fr[4,1]*100,1)+"% : "+NumToStr(fr[4,2],2)); Text_Delete(var5); var5 = Text_New(sdate,stime,fr[5,2],NumToStr(fr[5,1]*100,1)+"% : "+NumToStr(fr[5,2],2)); Text_Delete(var6); var6 = Text_New(sdate,stime,fr[6,2],NumToStr(fr[6,1]*100,1)+"% : "+NumToStr(fr[6,2],2)); Text_Delete(var7); var7 = Text_New(sdate,stime,fr[7,2],NumToStr(fr[7,1]*100,1)+"% : "+NumToStr(fr[7,2],2));
프로필 이미지
뮬리
2019-01-14
179
글번호 125232
지표
답변완료

시스템 수식 부탁드립니다.

스토케스틱 매매 - 20%선 밑에서 %K가 %D를 G.C 할때 매수 - 80%선 위에서 %K가 %D를 D.C할 때 매도 - 10,5,5 사용
프로필 이미지
미완
2019-01-14
163
글번호 125231
시스템