커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

정해진 시간에만 매매를 하고 싶은데, 수식이 어떻게 되나요?

정해진 시간만 매매를 하고자 합니다. 시간 09시 ~ 10시 17시 ~ 20시 22시 ~ 03시. 수식 부탁 드립니다~ 수고하세요.
프로필 이미지
백두에서한라
2019-05-20
243
글번호 128816
시스템
답변완료

문의드립니다.

문의드립니다. 전략창에서 시스템 성능 보고서의 [수익손실거래] 의 손실거래 연속 횟수 와 [그래프] 누적손익을 조건으로 매매 진입과 진입 종료를 하고 싶습니다. 진입시작 : (손실연속횟수 최대값 - 1) 에 도달하면 진입 시작 진입종료 : 진입 시작후 그래프의 누적손익이 진입 전 최대 이익대비 20% 이상 시 진입종료 간단한 식에 구현할수 있는 방법을 알려주시면 식에 대입하겠습니다. 감사합니다.
프로필 이미지
라떼처럼
2019-05-20
251
글번호 128815
시스템
답변완료

시스템 문의

현재 매수포지션일때 0.8 익절하면서 매도로 스위칭한다 현재 매도포시션일때 0.8 익절하면서 매수로 스위칭한다 위 두 경우 수식 부탁합니다
프로필 이미지
회원
2019-05-20
243
글번호 128807
시스템
답변완료

부탁드립니다

수고하십니가 오일옵션입니다 (data2~ data9) 아래수식 적용해보니 data5와data9에 시고저선이 나타지않고 아래0.000선에겹쳐서 나타남니다 수정부&#53447;드립니다 Var : cnt(0); Array : O2[10](0,data2),H2[10](0,data2),L2[10](0,data2); Array : O3[10](0,data3),H3[10](0,data3),L3[10](0,data3); Array : O4[10](0,data4),H4[10](0,data4),L4[10](0,data4); Array : O5[10](0,data5),H5[10](0,data5),L5[10](0,data5); Array : O6[10](0,data6),H6[10](0,data6),L6[10](0,data6); Array : O7[10](0,data7),H7[10](0,data7),L7[10](0,data7); Array : O8[10](0,data8),H8[10](0,data8),L8[10](0,data8); Array : O9[10](0,data9),H9[10](0,data9),L9[10](0,data9); if data2(bdate != bdate[1]) Then {O2[0] = data2(O);H2[0] = data2(H);L2[0] = data2(L); for cnt = 1 to 9 {O2[cnt] = O2[cnt-1][1]; H2[cnt] = H2[cnt-1][1];L2[cnt] = L2[cnt-1][1]; }} if H2[0] > 0 and data2(H) > H2[0] Then H2[0] = data2(H); if L2[0] > 0 and data2(L) < L2[0] Then L2[0] = data2(L); if data3(bdate != bdate[1]) Then {O3[0] = data3(O);H3[0] = data3(H);L3[0] = data3(L); for cnt = 1 to 9 {O3[cnt] = O3[cnt-1][1]; H3[cnt] = H3[cnt-1][1];L3[cnt] = L3[cnt-1][1]; }} if H3[0] > 0 and data3(H) > H3[0] Then H3[0] = data3(H); if L3[0] > 0 and data3(L) < L3[0] Then L3[0] = data3(L); if data4(bdate != bdate[1]) Then {O4[0] = data4(O);H4[0] = data4(H);L4[0] = data4(L); for cnt = 1 to 9 {O4[cnt] = O4[cnt-1][1]; H4[cnt] = H4[cnt-1][1];L4[cnt] = L4[cnt-1][1]; }} if H4[0] > 0 and data4(H) > H4[0] Then H4[0] = data4(H); if L4[0] > 0 and data4(L) < L4[0] Then L4[0] = data4(L); if data5(bdate != bdate[1]) Then {O5[0] = data5(O);H5[0] = data5(H);L5[0] = data5(L); for cnt = 1 to 9 {O5[cnt] = O5[cnt-1][1]; H5[cnt] = H5[cnt-1][1];L5[cnt] = L5[cnt-1][1]; }} if H5[0] > 0 and data5(H) > H5[0] Then H5[0] = data5(H); if L5[0] > 0 and data5(L) < L5[0] Then L5[0] = data5(L); if data6(bdate != bdate[1]) Then {O6[0] = data6(O);H6[0] = data6(H);L6[0] = data6(L); for cnt = 1 to 9 {O6[cnt] = O6[cnt-1][1]; H6[cnt] = H6[cnt-1][1];L6[cnt] = L6[cnt-1][1]; }} if H6[0] > 0 and data6(H) > H6[0] Then H6[0] = data6(H); if L6[0] > 0 and data6(L) < L6[0] Then L6[0] = data6(L); if data7(bdate != bdate[1]) Then {O7[0] = data7(O);H7[0] = data7(H);L7[0] = data7(L); for cnt = 1 to 9 {O7[cnt] = O7[cnt-1][1]; H7[cnt] = H7[cnt-1][1];L7[cnt] = L7[cnt-1][1]; }} if H7[0] > 0 and data7(H) > H7[0] Then H7[0] = data7(H); if L7[0] > 0 and data7(L) < L7[0] Then L7[0] = data7(L); if data8(bdate != bdate[1]) Then {O8[0] = data8(O);H8[0] = data8(H);L8[0] = data8(L); for cnt = 1 to 9 {O8[cnt] = O8[cnt-1][1]; H8[cnt] = H8[cnt-1][1];L8[cnt] = L8[cnt-1][1]; }} if H8[0] > 0 and data8(H) > H8[0] Then H8[0] = data8(H); if L8[0] > 0 and data8(L) < L8[0] Then L8[0] = data8(L); if data9(bdate != bdate[1]) Then {O9[0] = data9(O);H9[0] = data9(H);L9[0] = data9(L); for cnt = 1 to 9 {O9[cnt] = O9[cnt-1][1]; H9[cnt] = H9[cnt-1][1];L9[cnt] = L9[cnt-1][1]; }} if H9[0] > 0 and data9(H) > H9[0] Then H9[0] = data9(H); if L9[0] > 0 and data9(L) < L9[0] Then L9[0] = data9(L); plot2(O2[0],"data2시가");plot3(H2[0],"data2고가");plot4(L2[0],"data2저가"); plot5(O3[0],"data3시가");plot6(H3[0],"data3고가");plot7(L3[0],"data3저가"); plot8(O4[0],"data4시가");plot9(H4[0],"data4고가");plot10(L4[0],"data4저가"); plot11(O5[0],"data5시가");plot12(H5[0],"data5고가");plot13(L5[0],"data5저가"); plot14(O6[0],"data6시가");plot15(H6[0],"data6고가");plot16(L6[0],"data6저가"); plot17(O7[0],"data7시가");plot18(H7[0],"data7고가");plot19(L7[0],"data7저가"); plot20(O8[0],"data8시가");plot21(H8[0],"data8고가");plot22(L8[0],"data8저가"); plot23(O9[0],"data9시가");plot24(H9[0],"data9고가");plot25(L9[0],"data9저가");
프로필 이미지
파생돌이
2019-05-20
247
글번호 128804
지표

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

프로필 이미지
wscamtk
2019-05-20
27
글번호 128799
시스템
답변완료

문의

1. 아래 식이 재진입 한번만인가요 ? 아니면 한번만으로 해주세요 2. 그래도 비추세 구간에서 매매가 많은데 더 줄일수 없나요 ? 3. 종합지수가 0.8% 이상이면 매도 신호 금지 , 이하면 매수신호 금지를 추가 할 수 있나요 ? 4. 25일선 아래선 매도신호만 , 위에서 매수 신호만 실행하라 5. 3번 연속 손실나면 그날 매매는 중지 ... 6. 종합지수가 +0.3--0.3% 일때 ,+-0.31-+-0.8% 일때 , +->0.8% 일때 변수를 따로 설정해 놓 고 싶은데 가능 한가요 ? (ChgRate(0.3),Period(20),Change(3);) 질문이 많아서 죄송 합니다 항상 감사합니다 Input:ChgRate(0.3),Period(20),Change(3); Var:Row(0),Col(0),hiBar(0),loBar(0),HiCond(False),LoCond(False), LastStat(0),WorkBit(0); Var:HA_C(0),HA_O(0),HA_H(0),HA_L(0); Var:ZzOsc(0); Array : HiZZ[10,4](0), // 열번호 1:가격,2:Index,3:sDate,4:sTime LoZZ[10,4](0); #==========================================# HA_C = (O+H+L+C)/4; If IsNaN(HA_O[1]) Then HA_O = O; Else HA_O = (HA_O[1]+HA_C[1])/2; HA_H = max(H,HA_O,HA_C); HA_L = min(L,HA_O,HA_C); If Index == 1 Then { HiZZ[1,1] = HA_H; HiZZ[1,2] = 0; HiZZ[1,3] = sDate; HiZZ[1,4] = sTime; LoZZ[1,1] = HA_L; LoZZ[1,2] = 0; LoZZ[1,3] = sDate; LoZZ[1,4] = sTime; } If Index > 0 Then { hiBar = hiBar + 1; loBar = loBar + 1; } If HA_H[hiBar] < HA_H Then hiBar = 0; If HA_L[loBar] > HA_L Then loBar = 0; HiCond = LoZZ[1,1] * (1 + (ChgRate/100)) < HA_H and hiBar == 0; LoCond = HiZZ[1,1] * (1 - (ChgRate/100)) > HA_L and loBar == 0; WorkBit = 0; If HiCond and LoCond Then { If HiZZ[1,1] < HA_H and LoZZ[1,1] > HA_L Then { If HA_H - HiZZ[1,1] > LoZZ[1,1] - HA_L Then WorkBit = 1; Else If HA_H - HiZZ[1,1] < LoZZ[1,1] - HA_L Then WorkBit = -1; Else If LastStat == -1 Then WorkBit = 1; Else WorkBit = -1; } Else If LoZZ[1,1] > HA_L Then WorkBit = -1; Else If HiZZ[1,1] < HA_H Then WorkBit = 1; Else If LastStat == -1 Then WorkBit = 1; Else WorkBit = -1; } Else If HiCond Then WorkBit = 1; Else If LoCond Then WorkBit = -1; #==========================================# If WorkBit == 1 Then { If LastStat == -1 Then { For Row = 10 DownTo 2 { For Col = 1 To 4 { HiZZ[Row,Col] = HiZZ[Row-1,Col]; } } HiZZ[1,1] = HA_H; HiZZ[1,2] = Index; HiZZ[1,3] = sDate; HiZZ[1,4] = sTime; hiBar = -1; loBar = -1; } Else If HiZZ[1,1] < HA_H Then { HiZZ[1,1] = HA_H; HiZZ[1,2] = Index; HiZZ[1,3] = sDate; HiZZ[1,4] = sTime; hiBar = -1; loBar = -1; } LastStat = 1; } #==========================================# If WorkBit == -1 Then { If LastStat == 1 then { For Row = 10 DownTo 2 { For Col = 1 To 4 { LoZZ[Row,Col] = LoZZ[Row-1,Col]; } } LoZZ[1,1] = HA_L; LoZZ[1,2] = Index; LoZZ[1,3] = sDate; LoZZ[1,4] = sTime; hiBar = -1; loBar = -1; } Else If LoZZ[1,1] > HA_L then { LoZZ[1,1] = HA_L; LoZZ[1,2] = Index; LoZZ[1,3] = sDate; LoZZ[1,4] = sTime; hiBar = -1; loBar = -1; } LastStat = -1; } ZzOsc = HA_C - IFF(LastStat == -1,HiZZ[1,1],LoZZ[1,1]); input: n(0.5), n1(2), n2(1.3); if highest(H,Period) <= lowest(L,Period)*(1+Change/100) then { If CrossUp(ZzOsc,0) Then Buy("B"); if MarketPosition == 0 and MarketPosition(1) == 1 and IsExitName("StopTrailing",1) == true and ZzOsc > ZzOsc[1] and ZzOsc[1] > 0 Then buy("bb"); If CrossDown(ZzOsc,0) Then Sell("S"); if MarketPosition == 0 and MarketPosition(1) == -1 and IsExitName("StopTrailing",1) == true and ZzOsc < ZzOsc[1] and ZzOsc[1] < 0 Then sell("ss"); } SetStopTrailing(n,n1,PointStop); setstoploss (n2,pointstop);
프로필 이미지
구다이전설
2019-05-20
231
글번호 128795
시스템
답변완료

오류

if (sdate != sdate[1] and stime >= 101500) or (sdate != sdate[1] and stime >= 101500 and stime[1] < 101500) Then { var1 = O; var2 = TimeToMinutes(101500); Condition1 = false; Condition2 = false; } if TimeToMinutes(stime) <= var2+30 then { if H >= var1+40 Then Condition1 = true; if L <= var1-40 Then Condition1 = true; } if Condition1 == true then { plot1(var1-20); plot2(var1+60); plot3(var1+80); } if Condition2 == true then { plot4(var1+20); plot5(var1-60); plot6(var1-80); } 실제로 챠트에 나타나지않고 20.60.80 글자만 나타납니다.수식은 문외한이라서 어떻게 고쳐야 될지 몰라서 그러니 양해부탁합니다
프로필 이미지
레전드
2019-05-20
250
글번호 128794
지표
답변완료

부탁드립니다.

당일 평균가가 아닌 예를 들어 3일전 부터 평균가, 가능하다면 n일전 평균가 지표 부탁 드립니다. 미리 감사 드립니다. var:q(0); q=dayhigh(1); if q<>q[1] then { Var1=0; var2=0; } var1=var1+c; var2=var2+1; var3=var1/var2; plot1(var3);
프로필 이미지
yes
2019-05-20
245
글번호 128793
지표
답변완료

일봉이평선을 분봉에 나타내고 싶습니다

(1).일봉의 이평선을 분봉에 나타내고 싶은데요 이평선 종가 기준으로 지그재그로 표현이 안되고 수평라인이 생겼으면하고요 그 라인에 5일선이면 5일선이렇게 텍스트로 써졌으면 하는데요 (2).전일 시가 ,중심가, 고가, 저가, 종가, 당일 시가, 중심가 라인이 표현이 됐으면 하고요 그 라인에 텍스트 표시가 됐으면 합니다 부탁드려요
프로필 이미지
초보트레이더11
2019-05-19
311
글번호 128792
지표