커뮤니티
예스랭귀지 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선에겹쳐서 나타남니다
수정부탇드립니다
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 님에 의해서 삭제되었습니다.
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);
2019-05-20
245
글번호 128793
답변완료
일봉이평선을 분봉에 나타내고 싶습니다
(1).일봉의 이평선을 분봉에 나타내고 싶은데요
이평선 종가 기준으로 지그재그로 표현이 안되고 수평라인이 생겼으면하고요
그 라인에 5일선이면 5일선이렇게 텍스트로 써졌으면 하는데요
(2).전일 시가 ,중심가, 고가, 저가, 종가, 당일 시가, 중심가 라인이 표현이 됐으면 하고요
그 라인에 텍스트 표시가 됐으면 합니다
부탁드려요
2019-05-19
311
글번호 128792