커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1710
글번호 230811
답변완료
종목검색 수식 부탁드립니다 ^^
1.오늘의 거래량을 V 라하고
하루전 거래량을 V(1) 이라하고 이틀전 거래량을 V(2)라 했을 때
하루전 거래량 V(1)이 이틀전 거래량 V(2)의 5배이상이고
하루전 거래량 V(1)이 오늘의 거래량 V의 5배이상이고
240일 이동평균선을 mav=ma(C,240) 라 했을 때
mav <= mav(1)를 만족해서 240이동평균선이 하락중인 종목을 검색하려 합니다
2.결론
V(1) >= 5*V(2) and V(1) >= 5*V and mav <= mav(1)
위조건을 만족하는 종목을 검색하려 합니다
감사합니다
2021-12-24
748
글번호 154825
답변완료
안녕하세요. 수식 부탁합니다
90틱 보조지표로 외국인 개인선물 차이를 macd처럼 0선을 기준으로 매수가 많으먼
빨간색으로 매도가 많으면 파란색으로 나타날수있도록 부탁드립니다
외국인 매수는 빨간색,개인은 파란색
2021-12-24
654
글번호 154824
답변완료
날짜 계산 문의드립니다.
주어진 날짜를 주말이나 공휴일을 제외한 전 영업일로 변경하려면 어떻게 해야 하나요?
예를들어 '20211220'을 주말을 제외한 전 영업일인 '20211217'로 변경하는 방법이 궁금합니다.
2021-12-24
657
글번호 154820
답변완료
보조지표값 변수선언
안녕하세요
본인이 직접 작성한 보조지표내의 값은 어떻게 변수선언하나요
예를 들어 지표명이 "★지표-1" 내의 bb값이 1 이상이면 buy 를 작성하려고 합니다
참조데이터는 아래처럼 변수선언이 가능하던데
var : aa(0,Data2);
aa = Data2(c)
아래는 안되는데 수식부탁합니다
var : aa(0,★지표-1);
aa = ★지표1(bb)
if aa > 1 then
Buy("매수진입");
2021-12-24
533
글번호 154819
답변완료
gㅁㅁ
ㅁ
2021-12-23
572
글번호 154818
답변완료
진입 후 일자별로 stoploss를 다르게 설정하려고 합니다.
if marketposition == 1 then
{
if sdate == EntryDate Then
{
setstoploss(1,PercentStop);
}
if sdate >= EntryDate+1 and sdate < EntryDate+3 Then
{
setstoploss(0.5,PercentStop);
if CrossDown(C,삼일저가평균) Then
{
ExitLong("EX1",AtStop,삼일저가평균);
}
}
if sdate >= EntryDate+3 Then
{
setstoploss(0.2,PercentStop);
if CrossDown(C,삼일저가평균) Then
{
ExitLong("EX2",AtStop,삼일저가평균);
}
}
}
이렇게 작성했는데 시뮬을 돌리면 stop 값이 일별 진행과 상관없이 전부 동일하게 작은값으로 적용이 되어버립니다.
로직이 잘못된 것 같아 보이지는 않는데 이유를 모르겠어요.
2021-12-23
556
글번호 154817
답변완료
수식 문의 드려요
1분봉 기준으로 30분 신고가 발생시(크로스업 말구 앳스탑 명령어써서요) 매수
신저가 발생시 매도 이런식으로 시스템 수식 부탁드립니다
2021-12-23
716
글번호 154816
답변완료
수식부탁드려요
다음의 조건들을 복합활용한 종목 검색 수식을 부탁드립니다
MD=(eavg(C,12)-eavg(C,26))/C*100; //MACD를 종가대비 수식으로 변형한 것임
MDs=(eavg(MD,9))/C*100;
MD조건=MD>=MDs && MD(1)<=MD;
STO=Stochasticsslow(12,5); //스토캐스틱슬로우
STOs=eavg(Stochasticsslow(12,5),5);
STO조건=STO>=STOs && STO>=20;
S강세=STO>=STOs && STO>=KS;
DP=DIPlus(Period); //DMI지표, 기간 14
DM=DIMinus(Period);
AX=ADX(Period);
DPl=Lowest(DP,고저기간);
DMl=Lowest(DM,고저기간);
DM조건=DP>DM && DM<=KD;
D강세=DM==DMl && DM<=KD;
PN=PVI(C)+NVI(C); //PVI와 NVI지표혼합
PNs=AVG(PN,9);
PN조건=PN>PNs;
P강세=PN>PNs && PN==(highest(PN,26));
TX=Trix(TX기간); //TRIX지표
TXs=eavg(TX, T시그널);
TX조건=TX>TXs && TX(1)<=TX;
핸들A=100-(100/(1+TEMA(if((C-C(1))>0,(C-C(1)),0),9)/TEMA(if((C-C(1))<0,abs((C-C(1))),0),9))); //TEMA와 DEMA지표 활용
핸들B=100-(100/(1+DEMA(if((C-C(1))>0,(C-C(1)),0),9)/DEMA(if((C-C(1))<0,abs((C-C(1))),0),9)));
핸들DT=핸들B/핸들A*100;
핸들DTs=eavg(핸들DT,ps);
핸들조건=핸들DT>핸들DTs && 핸들DT>=100;
RM=RMI(5,11); //RMI지표
R강세=RM>=KR;
조건1=(MD조건+STO조건+DM조건+PN조건+TX조건+핸들조건)>=K; //K는 변수(3)
조건2=S강세 or D강세 or P강세 or R강세;
조건3=주봉 또는 월봉이 양봉이어야 함
1. 조건1과 조건3 이 만족할 때의 종목검색과 시스템매매신호
2. 조건1 && 조건2 && 조건3 이 동시만족할 때의 종목검색과 시스템매매신호
상기신호는 첫발생시에만 종목검색되어야하고, 매도는 위 조건이 만족하지 않는 상태가 되면 매도를 합니다
2021-12-23
778
글번호 154815
답변완료
재문의 드립니다 ㅠㅠ
답변 너무 감사드립니다.
주신 수식을 적용해 보았는데 콜과 풋이 하나로 움직이는 수식인데 가끔 콜이나 풋 둘중 하나에 가격만 변경되는 경우나 있네요... 이유를 도저히 모르겠습니다..
그리고 작은 차이에도 변경이 되서 그러는데 시가에 한번만 변경하고 장중에는 유지 하거나 정말 가능하다면 1시간에 한번씩 아니면 2시간에 한번씩만 비교하고 싶습니다. 반복적으로 넣어야되면 제가 작성하겠습니다 ㅠㅠ 항상 도움 주셔서 감사합니다
> 예스스탁 님이 쓴 글입니다.
> 제목 : Re : 지표 부탁드립니다
> 안녕하세요
예스스탁입니다.
1
if Var36=Var31 Then
랭귀지에서 같다라는 표현은 == 입니다.
=은 변수에 값을 저장할 떄 사용합니다.
2
아래와 같이 2개의 데이타의 절대값으로 간단히 작성하시면 됩니다.
var:opc(0),data2opc(0),data3opc(0),sbpbop(0),sscbop(0),hapsb(0),hapss(0),var1(0),var2(0),var3(0),var4(0),var5(0),var6(0),var7(0),var8(0),var9(0),var10(0),var11(0),var12(0),var13(0),var14(0),var15(0),var16(0),var17(0),var18(0)
,var19(0),var20(0),var21(0),var22(0);
var:pungsb(0),pungss(0),var31(0),var32(0),var33(0),var34(0),var35(0),var36(0),var37(0),var38(0),var39(0);
Input : Period1(20),Period2(10);
var : mindiff(0);
if stime >= 090000 and stime < 155500 then
{
mindiff = abs(Data2(c)-data3(c));
Var37 = Data2(c);
Var38 = Data3(c);
If abs(data4(c)-data8(c)) < mindiff Then
{
mindiff = abs(Data4(c)-data8(c));
Var37 = Data4(c);
Var38 = Data8(c);
}
If abs(data5(c)-data9(c)) < mindiff Then
{
mindiff = abs(Data5(c)-data9(c));
Var37 = Data5(c);
Var38 = Data9(c);
}
If abs(data6(c)-data10(c)) < mindiff Then
{
mindiff = abs(Data6(c)-data10(c));
Var37 = Data6(c);
Var38 = Data10(c);
}
If abs(data7(c)-data11(c)) < mindiff Then
{
mindiff = abs(Data7(c)-data11(c));
Var37 = Data7(c);
Var38 = Data11(c);
}
}
////현재가
plot4(c,"선물");
plot5(Var37,"콜");
plot6(-Var38,"풋");
즐거운 하루되세요
> yosong 님이 쓴 글입니다.
> 제목 : 지표 부탁드립니다
> var:opc(0),data2opc(0),data3opc(0),sbpbop(0),sscbop(0),hapsb(0),hapss(0),var1(0),var2(0),var3(0),var4(0),var5(0),var6(0),var7(0),var8(0),var9(0),var10(0),var11(0),var12(0),var13(0),var14(0),var15(0),var16(0),var17(0),var18(0)
,var19(0),var20(0),var21(0),var22(0);
var:pungsb(0),pungss(0),var31(0),var32(0),var33(0),var34(0),var35(0),var36(0),var37(0),var38(0),var39(0);
Input : Period1(20),Period2(10);
if stime >= 090000 and stime < 155500 then {
Var31=0;
Var32=0;
Var33=0;
Var34=0;
var35=0;
////시가
if data2(c)> data3(c) Then var31=Data2(c)/Data3(c); Else var31=Data3(c)/Data2(c);
if data4(c)> data8(c) Then var32=Data4(c)/Data8(c); Else var32=Data8(c)/Data4(c);
if data5(c)> data9(c) Then var33=Data5(c)/Data9(c); Else var33=Data9(c)/Data5(c);
if data6(c)> data10(c) Then var34=Data6(c)/Data10(c); Else var34=Data10(c)/Data6(c);
if data7(c)> data11(c) Then var35=Data7(c)/Data11(c); Else var35=Data11(c)/Data7(c);
Var36=MinList(Var31,Var32,var33,var34,Var35);
if Var36=Var31 Then Var37=Data2(c) ; Var38=Data3(c) ;
if Var36=Var32 Then Var37=Data4(c) ; Var38=Data8(c) ;
if Var36=Var33 Then Var37=Data5(c) ; Var38=Data9(c) ;
if Var36=Var34 Then Var37=Data6(c) ; Var38=Data10(c) ;
if Var36=Var35 Then Var37=Data7(c) ; Var38=Data11(c) ;
////현재가
plot4(c,"선물");
plot5(Var37,"콜");
plot6(-Var38,"풋");
ATM중 가장 값에 차이가 덜나는 값을 구하려고 위와 같은 식을 사용하였는데
맞을때도 있고 틀리게 나올때가 있네요
ATM 콜 3.00 ATM 풋 4.00
ATM+1 콜 7.00 ATM+1 풋 3.00
이럴때 ATM 콜 3.00 ATM 풋 4.00 값을 선택하게 하고 싶습니다
ATM 콜 Data2(c) ATM 풋 Data3(c)
ATM+1 콜 Data4(c) ATM+1 풋Data8(c)
ATM+2 콜 Data5(c) ATM+2 풋 Data9(c)
ATM-1 콜 Data6(c) ATM-1 풋 Data10(c)
ATM-2 콜 Data7(c) ATM-2 풋 Data11(c)
2021-12-23
619
글번호 154813