커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
6176
글번호 230811
답변완료
지표값 문의 드립니다
안녕하세요 ^^
다름이 아니라 현재봉에서 이전 60봉째의 날짜를 얻고 싶습니다
날짜값을 예로 20180302 이런식으로 얻고싶은데 도움 부탁드리겠씁니다
2018-03-02
195
글번호 117066
답변완료
문의드립니다
1
주식 매수 진입후
상한가 청산식을 알고싶습니다
상한가의 -1% 되는 정도 지점에서 청산하고 싶습니다
2
주식 매수 진입후
최고가 대비 N% 하락하면 청산식
감사합니다
2018-03-02
208
글번호 117063
답변완료
문의드립니다.
질문1
5분봉에서 당일 거래량만 누적해서 나타낸 다음
전 거래일(고정값) 거래량과 비교해서 몇배인지 지표를 표현하고 싶은데 어떻게 해야하나요??
ps/ 일봉에서 비교하면 단순히 몇배인지 볼 수는 있으나 어느시점에 전 거래일 거래량을 넘어서는지 궁금해서 질문드립니다.
질문2
5분봉에서 이평 20, 60, 120선이 만족하고
당일 5분봉 이내에서만 거래량이 10만주 이상 터진 봉이 하나 이상인 종목을 검색하고 싶습니다.
2018-03-02
208
글번호 117062
답변완료
부탁드립니다
매수조건은 매일 오후2시가 되면 자동매수
매도조건은 다음날 아침 시가에 매도.
부탁드립니다
2018-03-01
196
글번호 117061
답변완료
문의
56881번 재문의입니다.
아래 답변식을 적용하여 표시를 하면 원하는결과가 되지안고 만약 직전 고점이
320.05 라하면 이와 같은 봉에서도 표시가 되어지네요
안녕하세요
예스스탁입니다.
답변내용
2
검색식으로 작성해 봉에 점을 찍어 보셔야 할것 같습니다.
data1이 N개봉 최고가일때 data2도 N개봉 최고가이면 빨간색 아니면 파란색
input : N(10);
if data1(H == highest(H,N)) Then{
if data2(H == highest(H,N)) Then
Plot1(H,"검색",red);
else
Plot1(H,"검색",blue);
}
질문내용
2번;
data1 선물 최근고점 (고점주기는 변수로입력해서 조정할수있게) 일때
참조 data2 도 최근고점 인지 고점이 아니면 수직선을 그리던지 아니면 화살표가 생기던지
어떻게 표현할수 있는 방법이 있을까요?
2018-03-02
212
글번호 117060
답변완료
수익금을 지속 반영하여 매매수량을 지속 늘리는 방법?
안녕하세요.
시스템 시뮬레이션시에 나의 계좌에서 수익나는 금액을 지속 반영하여 복리 효과를 시뮬레이션 해보고 싶습니다.
할수 있는 방법이 있는지요?
예를들어 1천만원으로 시작할때 1천원 주식 1000주를 매매했다고 가정하고,
일주일후 가격이 올라 계좌 잔고가 1200만원이 되었다고 가정하겠습니다.
다시 1000원짜리 종목을 매매할때 1200만원어치를 모두 사려고 할때 어떻게 계산하면 좋은지 예제를 부탁드립니다.
감사합니다.
2018-03-01
226
글번호 117059
답변완료
검색식 작성문의드립니다
DMI 지표와 관련해서
1. ADX는 20 이상에서 상승추세 유지(우상향)
2. D+ 는 D-보다 위에 위치
3. DMI는 20봉개중(1개월이내)에서 한번이라도 50이상 돌파
3가지 조건을 동시에 만족하는 조건식좀 부탁드립니다
2018-03-01
196
글번호 117058
답변완료
문의드립니다
챠트에 적용된 지표 출력식이 plot1(close, "지정된이름", red)이라 하면
예스스팟 챠트객체에서 GetIndicatorData로 close 값은 반환해서 사용할 수 있으나,
"지정된이름"이나 색상값(red)을 반환하여 사용할 수 있는 방법이 없는 것 같읍니다.
지표식의 여러 plot 값들을 0 으로 지정해 놓고 지정된이름을 달리하여 지표식을
작성하여 사용하고 있어 "지정된이름" 과 red 같은 색상값을 반환하여 사용하고자
하오니 방법을 알려주시기 바라며, 없다면 해당 역활을 할수 있도록 매소드를 수정하거나
새로 만드러 주시면 감사하겠읍니다.
2018-03-01
202
글번호 117057
답변완료
감사합니다 고개숙여 감사드려요
아래 3개의검색식 하나로 만들어 주세요
1, 장시작후 2분후 검색되게 부탁드리려요( 외부변수부탁)
2, 3개검색식 공통 되는부분은 통합 부탁드립니다
3, 3개검색식 포착 되는 종목중 거래대금 상위 7개 이내로 부탁드립니다
1, 종목검색식
if CrossUp(ma(c,5),ma(c,10)) and close>(ma(c,15)) Then
buy();
if Crossdown(ma(c,5),ma(c,10)) and close<(ma(c,15)) Then
sell();
2,종목검색식
var : 상한가(0), UpLimit(0);
var : up1(0), up2(0), up3(0), up4(0), up5(0),up6(0),Up7(0);
if date >= 19981207 then {
if date < 20050328 && CodeCategory() == 2 then
UpLimit = (BP[0] * 1.12);
Else if date >= 20050328 and date < 20150615 Then
UpLimit = (BP[0] * 1.15);
Else
UpLimit = (BP[0] * 1.30);
if CodeCategory() == 2 then {
if date >= 20030721 then {
up1 = int(UpLimit/100+0.00001)*100;
up2 = int(UpLimit/100+0.00001)*100;
up3 = int(UpLimit/100+0.00001)*100;
up4 = int(UpLimit/50+0.00001)*50;
up5 = int(UpLimit/10+0.00001)*10;
up6 = int(UpLimit/5+0.00001)*5;
up7 = int(UpLimit/1+0.00001)*1;
}
else {
up1 = int(UpLimit/1000+0.00001)*1000;
up2 = int(UpLimit/500+0.00001)*500;
up3 = int(UpLimit/100+0.00001)*100;
up4 = int(UpLimit/50+0.00001)*50;
up5 = int(UpLimit/10+0.00001)*10;
up6 = int(UpLimit/10+0.00001)*10;
up7 = int(UpLimit/1+0.00001)*1;
}
}
Else {
up1 = int(UpLimit/1000+0.00001)*1000;
up2 = int(UpLimit/500+0.00001)*500;
up3 = int(UpLimit/100+0.00001)*100;
up4 = int(UpLimit/50+0.00001)*50;
up5 = int(UpLimit/10+0.00001)*10;
up6 = int(UpLimit/5+0.00001)*5;
up7 = int(UpLimit/1+0.00001)*1;
}
if CodeCategory() == 1 || CodeCategory() == 2 then {
if sdate < 20101004 Then{
If BP >= 500000 Then
상한가 = up1;
Else If BP >= 100000 Then
상한가 = iff(up2>=500000, up1, up2);
Else If BP >= 50000 Then
상한가 = iff(up3>=100000, up2, up3);
Else If BP >= 10000 Then
상한가 = iff(up4>=50000, up3, up4);
Else If BP >= 5000 Then
상한가 = iff(up5>=10000, up4, up5);
Else If BP >= 1000 Then
상한가 = iff(up5>=5000, up5, up6);
Else
상한가 = iff(up6>=1000, up6, up6);
}
Else{
If BP >= 500000 Then
상한가 = up1;
Else If BP >= 100000 Then
상한가 = iff(up2>=500000, up1, up2);
Else If BP >= 50000 Then
상한가 = iff(up3>=100000, up2, up3);
Else If BP >= 10000 Then
상한가 = iff(up4>=50000, up3, up4);
Else If BP >= 5000 Then
상한가 = iff(up5>=10000, up4, up5);
Else If BP >= 1000 Then
상한가 = iff(up5>=5000, up5, up6);
Else
상한가 = iff(up6>=1000, up6, up7);
}
}
else if CodeCategory() == 8 || CodeCategory() == 9 then { // ETF
상한가 = up6;
}
}
var1 = ma(M,5);
if var1 >= 100000000 and
countif(H >= 상한가,100) >= 1 and
C >= 1000 and C <= 50000 and
Upvol/DownVol*100 >= 100 and
C > H[1] Then
find(1);
3,종목검색식
ar1 = ma(C,20);
var2 = ma(C,60);
var3 = ma(c,120);
if m >= 1000000 and
C >= O*1.05 and C < O*1.30 and
var1 > var2 and var2 > var3 Then
find(1);
2018-03-01
240
글번호 117056