커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
5559
글번호 230811
답변완료
수식 문의드립니다
20캔들 최고가에서 9번째 음봉 저가를 표시한다
20캔들 최저가에서 9번째 양봉 고가를 표시한다
감사합니다
2019-04-09
254
글번호 127712
답변완료
이동평균
이동평균
5,10,20,60,120 에서 정배열일때
강조하고 싶습니다.
별표시로 나타날수 있으면 좋겠습니다.
감사하겠습니다.
2019-04-09
216
글번호 127711
답변완료
최고고가대비최저저가
기간은 입력할 수 있게 해주시고요
n일동안 최고고가(종가아닙니다.) 대비 최저저가가(종가아닙니다)
-30% 에서 -50%인 종목 검색식 부탁드립니다.
2019-04-09
243
글번호 127709
답변완료
함수변환 요청
안녕하세요?
아래는 시그널메이커로 작성된 스크립트입니다.
예스랭귀지로 변환 요청드립니다.
Vars : st(0), et(0);
V1 = Dayofweek((10000 * Year(D)) + (100 * 3) + 1);
If V1 = 0 Then Value2 = 8
Else Value2 = 15 - V1; // 3월 두번째 일요일 날짜
V2 = Dayofweek((10000 * Year(D)) + (100 * 11) + 1);
If V2 = 0 Then Value4 = 1
Else value4 = 8 - V2; // 11월 첫번째 일요일 날짜
If date > (10000 * Year(D)) + (100 * 3) + value2
And date < (10000 * Year(D)) + (100 * 11) + value4 Then
Begin
st = 070000; // 써머타임 적용 시, 장시작 시간
et = 060000; // 써머타임 적용 시, 장종료 시간
v77 = 150000;
v88 = 200000;
End
Else
Begin
st = 080000; // 장 시작 시간
et = 070000; // 장 종료 시간
v77 = 160000;
v88 = 210000;
End;
condition1 = (IntPortion(time/10000) > IntPortion(et/10000)
And IntPortion(time[1]/10000) <= IntPortion(et/10000)) Or st <> st[1];
/////////////////////////////////////////////////////////////////
Var : vTT(0), vPrice1(0), vPrice2(0);
IF condition1 Then vTT = 0;
If TIME[1] < v77 And v77 <= TIME Then vPrice1 = data2(C);
If TIME[1] < v88 And v88 <= TIME Then vPrice2 = data2(C);
Vars : TCOND(False);
If v88 < et Then
Begin
If v88 < TIME And TIME <= et Then TCONd = True
Else TCONd = False;
End
Else
Begin
If v88 < TIME Or TIME <= et Then TCOND = True
Else tCOND = False;
End;
If TCOND And vTT = 0 And vPrice1 > 0 And vPrice2 > 0 Then
Begin
if vPrice1 > vPrice2 Then
Begin
buy("b");
vTT = 1;
End;
if vPrice1 < vPrice2 Then
Begin
sell("s");
vTT = 1;
End;
End;
2019-04-09
260
글번호 127706
답변완료
이격도 지표 요청 드립니다.
* 많은 도움에 고맙습니다.
* 현재봉이 아닌 5봉전 기준으로 이격도 수식좀 요청 드립니다. (5,20)
* 고맙습니다.
2019-04-09
259
글번호 127699
답변완료
함수수정요청
안녕하세요?
아래 작성주신 스크립트를 수정요청드립니다.
참조함수의 당일시가와 특정시간 가격을 비교하여 진입 신호를 생성하였습니다.
그런데 참조함수의 당일시가가 아닌 당일 특정 시간의 가격과 또다른 당일 가격을 비교하여 진입신호를 생성하고 싶습니다.
즉 참조함수의 당일시가(O2 = data2(O))가 아닌 특정시간(110000, 써머타임해지시 120000)으로 수정하고 싶습니다.
Var : Summer(False,data2),Year(0,data2);
var : v1(0,data2),v2(0,data2),v3(0,data2),v4(0,data2);
var : T(0,data2),O2(0,data2),ST(0,data2);
Year = data2(Floor(sdate/10000));
V1 = (10000 * Year) + (100 * 3) + 1;
V2 = data2(15 - dayofweek(v1)); // 3월 두번째 일요일 날짜
v3 = (10000 * Year) + (100 * 11) + 1;
v4 = data2(8 - dayofweek(v3)); // 11월 첫번째 일요일 날짜
Summer = data2(sdate > (10000 * Year) + (100 * 3) + v2
And sdate < (10000 * Year) + (100 * 11) + v4);
if data2(bdate != bdate[1]) Then
{
T = 0;
O2 = data2(O);
if summer == true Then
ST = 160000;
Else
ST = 170000;
}
if Summer == true then
{
if data2((sdate != sdate[1] and stime >= ST) or
(sdate == sdate[1] and stime >= ST and stime[1] < ST)) Then
{
if data2(C) > O2 Then
T = 1;
if data2(C) < O2 Then
T = -1;
}
}
if T == 1 and data2(CrossDown(L,O2)) Then
{
T = 2;
buy("b");
}
if T == -1 and data2(crossup(H,O2)) Then
{
T = -1;
sell("s");
}
2019-04-08
266
글번호 127698
답변완료
문의
2016년 8월 1일부로 선물옵션 거래종료시간이 3시45분으로 변경되었습니다.
2012년부터 시뮬레이션을 하고 싶습니다.
아래수식을 이용하되 거래일을 2부로 나누는 수식을 부탁드립니다.
input:전반부 시작(20120615),전반부 끝(20160731);
input:후반부 시작(20160801),후반부 끝(20190331);
********************************************************************
안녕하세요
예스스탁입니다.
input:만기청산시간(151840), 만기외청산시간(153340);
var : nday(0),Week(0);
nday = date - int(date/100)*100;
Week = DayOfWeek(date);
if nday >= 8 and nday <= 14 and
Week == 4 then
SetStopEndofday(만기청산시간);
Else
SetStopEndofday(만기외청산시간);
즐거운 하루되세요
2019-04-08
221
글번호 127697
답변완료
부탁좀 드립니다
전일 고가+저가 /2
전일 시가 + 종가 /2
전일 시가선
전일 종가선
전일 고가선
전일 저가선
아래 지표좀 부탁합니다
2019-04-08
233
글번호 127696
답변완료
사용하고 있는 수식에서 하루에 1회만 거래될수 있는 수식 추가 부탁드림니다.
쿠르드 오일입니다. 분봉 매매입니다. (30분봉)
아래수식에 하루에 매수-매도든 상관없이 1일 1회진입 하는 수식이 추가될수 있도록
부탁드릴께요~~
이것저것 변수를 부치다보니 저도 수식이 관리가 안되네요.ㅠㅠ
지금 식은 하루에 많을때는 4-6번도 더 진입이 되네요~~
input : p1(3),p2(1),af(0.02), maxAF(0.2);
input : 즉시익절1(85),봉완성익절1(58),올랐다본전틱수1(38),본전청산1(-32),즉시손절1(72),봉완성손절1(70);
input : 즉시익절2(61),봉완성익절2(54),올랐다본전틱수2(31),본전청산2(-14),즉시손절2(84),봉완성손절2(58);
input : N1(3),N2(4);
Input :N3(5),N4(30),매수제한(0.1),매도제한(0.13);
input : 즉시익절3(90),봉완성익절3(55),올랐다본전틱수3(19),본전청산3(-36),즉시손절3(84),봉완성손절3(74);
input : 즉시익절4(94),봉완성익절4(45),올랐다본전틱수4(39),본전청산4(-25),즉시손절4(60),봉완성손절4(50);
Input : RSIPeriod(10),SimPeriod(10);
Input : RSI상한선1(93),RSI하한선1(21),Sim상한선1(91),Sim하한선1(1);
Input : RSI상한선2(93),RSI하한선2(23),Sim상한선2(91),Sim하한선2(1);
Input : P100(1000),P200(200),P300(600),P400(300);
Input : MFIPeriod(20),P1000(32),P2000(91),P3000(24),P4000(90);
Input : ADXP(2);
Input : BBUPPeriod(4),dvUP(0.9),BBDOWNPeriod(4),dvDW(0.5);
Input : EnvelopePeriod1(3),EnvelopePercent1(0.03),EnvelopePeriod2(5),EnvelopePercent2(0.02);
Input : cciperiod(20),I1(6),I2(10),I3(9),I4(18);
var : cnt(0),sum1(0),sum2(0),avg1(0),avg2(0),avg3(0),T(0),mav2(0),mav3(0),value(0),RSIV(0),Simri(0),value100(0),CCIO(0);
var : sum3(0),Tcond(false),adxv(0);
value100 = MFI(MFIPeriod);
RSIV = RSI(RSIPeriod);
Simri = Simrido(SimPeriod);
CCIO = CCI(cciPeriod);
var1 = CSar(af,maxAF);
Var4 = highest(H,N3);
Var5 = lowest(L,N3);
var1 = CSar(af,maxAF);
Var6 = highest(H,N4);
Var7 = lowest(L,N4);
Var8 = BollBandUp(BBUPPeriod,dvUP);
Var9 = BollBandDown(BBDOWNPeriod,dvDW);
Var10 = EnvelopeUp(EnvelopePeriod1,EnvelopePercent1);
var11 = EnvelopeDown(EnvelopePeriod2,EnvelopePercent2);
ADXV = ADX(ADXP);
if DayClose(N2) > 0 Then
{
sum1 = 0;
sum2 = 0;
for cnt = 0 to N2-1
{
if cnt < N1 Then
sum1 = sum1 + DayClose(cnt);
if cnt < N2 Then
sum2 = sum2 + DayClose(cnt+1);
}
avg1 = sum1/N1;
avg2 = sum2/N2;
T = 0;
if avg1 >= avg2 Then
T = 1;
if avg1 < avg2 Then
T = -1;
if T == 1 Then
{
#골드가 발생하면
if var1 > C Then
{
#value1에 봉번호 저장
value1 = index;
#value2에 종가 저장
value2 = C;
}
#데드가 발생하면
If var1 < C Then
{
#value3에 봉번호 저장
value3 = index;
#value4에 종가 저장
value4 = C;
}
#무포지션이고
#골드이후 10개봉이상 경과했고
#종가가 직전 10봉의 최고가보다 크고
#종가가 골드봉의 종가보다 크면
#매수
if MarketPosition == 0 and
index >= value1+P1 and
C > highest(H,P1)[1] and
C <= Var4-(Var4-Var5)*매수제한 and
RSIV < RSI상한선1 and
Simri < Sim상한선1 and
V > P100 and
value100 >= P1000 and
ADXV > ADXV[1] and
c > Var8 and
c > Var10 and
CCIO > I1 and
C > value2 then
buy("매수",OnClose,def,1);
#무포지션이고
#데드이후 10개봉이상 경과했고
#종가가 직전 10봉의 최저가보다 작고
#종가가 데드봉의 종가보다 작으면
#매도
if MarketPosition == 0 and
index >= value3+P2 and
C < Lowest(L,P2)[1] and
C >= Var7+(Var6-Var7)*매도제한 and
RSIV > RSI하한선1 and
Simri > Sim하한선1 and
V > P200 and
value100 <= P2000 and
ADXV > ADXV[1] and
c < Var9 and
c < Var11 and
CCIO < I2 and
C < value4 then
Sell("매도",OnClose,def,1);
if MarketPosition == 1 then
{
ExitLong("즉시익절1",AtLimit,EntryPrice+PriceScale*즉시익절1);
if C >= EntryPrice+PriceScale*봉완성익절1 Then
ExitLong("봉완성익절1");
if highest(H,BarsSinceEntry) >= EntryPrice+PriceScale*올랐다본전틱수1 Then
ExitLong("본전청산1",AtStop,EntryPrice+PriceScale*(본전청산1));
ExitLong("즉시손절1",AtStop,EntryPrice-PriceScale*즉시손절1);
if c <= EntryPrice-PriceScale*봉완성손절1 Then
ExitLong("봉완성손절1");
}
if MarketPosition == -1 then
{
ExitShort("즉시익절2",AtLimit,EntryPrice-PriceScale*즉시익절2);
if C <= EntryPrice-PriceScale*봉완성익절2 Then
ExitShort("봉완성익절2");
if lowest(L,BarsSinceEntry) <= EntryPrice-PriceScale*올랐다본전틱수2 Then
ExitShort("본전청산2",AtStop,EntryPrice-PriceScale*(본전청산2));
ExitShort("즉시손절2",AtStop,EntryPrice+PriceScale*즉시손절2);
if c >= EntryPrice+PriceScale*봉완성손절2 Then
ExitShort("봉완성손절2");
}
}
}
if T == -1 Then
{
#골드가 발생하면
if var1 > C Then
{
#value1에 봉번호 저장
value1 = index;
#value2에 종가 저장
value2 = C;
}
#데드가 발생하면
If var1 < C Then
{
#value3에 봉번호 저장
value3 = index;
#value4에 종가 저장
value4 = C;
}
#무포지션이고
#골드이후 10개봉이상 경과했고
#종가가 직전 10봉의 최고가보다 크고
#종가가 골드봉의 종가보다 크면
#매수
if MarketPosition == 0 and
index >= value1+P1 and
C > highest(H,P1)[1] and
C <= Var4-(Var4-Var5)*매수제한 and
RSIV < RSI상한선2 and
Simri < Sim상한선2 and
V > P300 and
value100 >= P3000 and
ADXV > ADXV[1] and
c > Var8 and
c > Var10 and
CCIO > I3 and
C > value2 then
buy("매수2",OnClose,def,1);
#무포지션이고
#데드이후 10개봉이상 경과했고
#종가가 직전 10봉의 최저가보다 작고
#종가가 데드봉의 종가보다 작으면
#매도
if MarketPosition == 0 and
index >= value3+P2 and
C < Lowest(L,P2)[1] and
C >= Var7+(Var6-Var7)*매도제한 and
RSIV > RSI하한선2 and
Simri > Sim하한선2 and
V > P400 and
value100 <= P4000 and
ADXV > ADXV[1] and
c < Var9 and
c < Var11 and
CCIO < I4 and
C < value4 then
Sell("매도2",OnClose,def,1);
if MarketPosition == 1 then
{
ExitLong("즉시익절3",AtLimit,EntryPrice+PriceScale*즉시익절3);
if C >= EntryPrice+PriceScale*봉완성익절3 Then
ExitLong("봉완성익절3");
if highest(H,BarsSinceEntry) >= EntryPrice+PriceScale*올랐다본전틱수3 Then
ExitLong("본전청산3",AtStop,EntryPrice+PriceScale*(본전청산3));
ExitLong("즉시손절3",AtStop,EntryPrice-PriceScale*즉시손절3);
if c <= EntryPrice-PriceScale*봉완성손절3 Then
ExitLong("봉완성손절3");
}
if MarketPosition == -1 then
{
ExitShort("즉시익절4",AtLimit,EntryPrice-PriceScale*즉시익절4);
if C <= EntryPrice-PriceScale*봉완성익절4 Then
ExitShort("봉완성익절4");
if lowest(L,BarsSinceEntry) <= EntryPrice-PriceScale*올랐다본전틱수4 Then
ExitShort("본전청산4",AtStop,EntryPrice-PriceScale*(본전청산4));
ExitShort("즉시손절4",AtStop,EntryPrice+PriceScale*즉시손절4);
if c >= EntryPrice+PriceScale*봉완성손절4 Then
ExitShort("봉완성손절4");
}
}
2019-04-08
259
글번호 127695