커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1595
글번호 230811
답변완료
수식변환의뢰
수식변환의뢰
안녕하세요
다음조건을 수식으로 변환 부탁드립니다.
1. 지표수식
0봉전 종가가 20봉중 신고가 라인
2.강세표시수식(1분 주기) 아래 1. 2. 3 조건을 만족할 때 강세표시
1) 0봉전 시가 < 0봉전 종가 and
2) 0봉전 Bollinger Band(50,2) 상한선 1봉 연속상승 and
3) 1봉전(중) 종가대비 0봉전 종가등락률 1.1%이상 30%이하
3. 종목검색수식
주가범위: 0일전 종가가 2000 이상 9999999 이하
[일]거래량:50000이상 999999999이하
[일]1봉전(중) 종가대비 0봉전 종가등락률 6%이상
[1분]1봉전(중) 종가대비 0봉전 종가등락률 1.5%이상 30%이하
[일]0봉전 시가 < 0봉전 종가
[1분]0봉전 시가 < 0봉전 종가
[일]0봉전 종가가 20봉중 신고가 or 가:[일]0봉전 종가가 40봉중 신고가
[1분]0봉전 Bollinger Band(50,2) 상한선 2봉 연속상승
2022-12-20
1446
글번호 164696
답변완료
수식요청드려요
스토캐스틱 슬로우 기본 k와 d 선이
기준선80 이하일 경우 매수
2022-12-20
998
글번호 164694
답변완료
특정 분차트 참조시 시뮬레이션 결과와 가까운 청산 방식문의
안녕하세요
지금 테스트 하고있는 수식에서 기관 데이터를 참조하는 부분이 있습니다.(분차트에서)
이때 참조 데이터의 실시간 미반영 혹은 참조 오류시, 실매매에서는 매수매도
신호가 반대로 들어갔는데
시뮬레이션 결과로는 오류가 변경되서 매수 매도 신호가 정상적으로 들어갔습니다.
(실매매와 차이 발생)
실제 매매 전략 차트 창도 이후 시뮬레이션 결과와 같이 수정된점이 확인 되었는데요
이런 경우 실제 매매와 최대한 비슷한 시뮬레이션 결과를 얻기 위해서
강제 청산 에서 봉 완성시로 세팅시 그나마 좀 더 현실치와 비슷하게 시뮬레이션
가능할지 문의드립니다.
감사합니다.
2022-12-20
1110
글번호 164693
답변완료
문의드립니다
분봉 차트상에서
1. 하루를 시간상 절반 두 구간으로 나눈다( 9:00~ 12:15 ~ 3:30)
2. 하루의 저가가 전반부에 있고 고가가 후반부에 있다면
전반부의 중간지점에 저가 높이에 점을 찍고
후반부의 중간 지점에 고가 높이에 점을 찍는다
반대의 경우도 마찬가지이다.
만일 전반부에 저가와 고가가 다 몰려있을경우
전반부에 저가고가의 중간값으로 점을 찍고
후반부에는 종가가 전체 레인지 구간의 중앙보다 상단에 있을경우 고점을 찍고
하단에 있을경우 저점을 찍는다
만일 후반부에 저가와 고가가 다 몰려있을경우
후반부에 저가고가의 중간값으로 점을 찍고
전반부에는 시가가 전체 레인지 구간의 중앙보다 상단에 있을경우 고점을 찍고
하단에 있을경우 저점을 찍는다
물론 실시간이 아닌 하루가 끝난후의 일일 고가 저가로 판단한다.
매일두개씩 만들어지는 점을 직선으로 잇는다.
말로 설명이 부족할것 같아서 그림을 그려서 첨부해보았습니다.
잘될지 모르겠네요 예스스탁의 노고에 언제나 감사드립니다.
2022-12-20
1404
글번호 164692
답변완료
수식전환 부탁드립니다
추운 날씨에 수고 많으십니다.
아래 수식을 예스로 변환 부탁드립니다.
수식1
valuewhen(1,avg(c,period)>avg(c,period,1),avg(c,period))
수식2
valuewhen(1,avg(c,period)<avg(c,period,1),avg(c,period))
수식3
avg(c,period)
period 20
감사합니다.
2022-12-19
1234
글번호 164690
답변완료
수정부탁드립니다
수정부탁드립니다. 사각박스와동일하게 부탁드립니다.
input :Peod(20),색상두께(40);
Var:상승색a(Red), 하락색a(Lime);
Var:jr(0),gT(0),Tj(0),Tk(0);
Var: 고11(0),고12(0),시간11(0),시간12(0),선TL1(0),선TL(0),
고21(0),고22(0),시간21(0),시간22(0),Vlue11(0),Vlue12(0),ddt(0),t(0),t1(0),
고31(0),고32(0),시간31(0),시간32(0);
Array:고Val[20](0),저val[20](0),고Bar[20](0),저Bar[20](0);
Array:dr[7](0),dfr[7](0);
var : dbox(0),dbox1(0);
vars: xClose(0),xOpen(0),xHigh(0),xLow(0);
dr[0] = 0;
dr[1] = 2;
dr[2] = 3.;
dr[3] = -1;
dr[4] = -2.;
dr[5] = 1;
dr[6] = 0.5;
For jr = 0 To 19
{
고Bar[jr] = 고Bar[jr] + 1;
저Bar[jr] = 저Bar[jr] + 1;
}
if crossup(c,highest(H,Peod)[1]) Then
gT = 1;
if CrossDown(c,Lowest(L,Peod)[1]) Then
gT = -1;
If gT == 1 Then
{
If gT[1] != 1 Then
{
For jr = 18 DownTo 0
{
고Val[jr+1] = 고Val[jr];
고Bar[jr+1] = 고Bar[jr];
}
고Val[0] = H;
고Bar[0] = 0;
고11 = Date[저Bar[0]];
시간11 = stime[저Bar[0]];
Vlue11 = 저val[0];
고12 = Date[고Bar[0]];
시간12 = stime[고Bar[0]];
Vlue12 = 고Val[0];
고31 = Date[저Bar[0]];
시간31 = stime[저Bar[0]];
고32 = Date[0];
시간32 = stime[0];
for jr = 0 to 5
{
dfr[jr] = 저val[0] + ((고Val[1] - 저val[0]) * dr[jr]);
}
Box_SetEnd(dbox,고11,시간11,Vlue11);
dbox = box_new(고11,시간11,Vlue11,고12,시간12,Vlue12);
Box_SetColor(dbox,상승색a);
Box_SetFill(dbox,true,색상두께);
xOpen = Vlue11;
}
xClose = Vlue12;
}
If 고Val[0] < H Then
{
고Val[0] = H;
고Bar[0] = 0;
고12 = Date[고Bar[0]];
시간12 = stime[고Bar[0]];
Vlue12 = 고Val[0];
고32 = Date[0];
시간32 = stime[0];
}
Box_SetEnd(dbox,NextBarSdate,NextBarStime,Vlue12);
If gT == -1 Then
{
If gT[1] != -1 Then
{
For jr = 18 DownTo 0
{
저val[jr+1] = 저val[jr];
저Bar[jr+1] = 저Bar[jr];
}
저val[0] = L;
저Bar[0] = 0;
고11 = Date[고Bar[0]];
시간11 = stime[고Bar[0]];
Vlue11 = 고Val[0];
고12 = Date[저Bar[0]];
시간12 = stime[저Bar[0]];
Vlue12 = 저val[0];
고21 = Date[고Bar[0]];
시간21 = stime[고Bar[0]];
고22 = Date[0];
시간22 = stime[0];
for jr = 0 to 6
{
dfr[jr] = 저val[1] + ((고Val[0] - 저val[1]) * dr[jr]);
}
Box_SetEnd(dbox,고11,시간11,Vlue11);
dbox = box_new(고11,시간11,Vlue11,고12,시간12,Vlue12);
Box_SetColor(dbox,하락색a);
Box_SetFill(dbox,true,색상두께);
xClose = Vlue12;
}
xOpen = Vlue11;
If 저val[0] > L Then
{
저val[0] = L;
저Bar[0] = 0;
고12 = Date[저Bar[0]];
시간12 = stime[저Bar[0]];
Vlue12 = 저val[0];
고22 = Date[0];
시간22 = stime[0];
}
Box_SetEnd(dbox,NextBarSdate,NextBarStime,Vlue12);
}
if XClose > Xopen Then
PlotPaintBar(h,l,"강조",Red);
else if XClose < Xopen Then
PlotPaintBar(h,l,"강조",Blue);
2022-12-20
1200
글번호 164689
답변완료
지표 질문입니다
1. 월봉 시가를 일간 차트에 표시한다
2. 월봉 시가를 틱 차트에 표시한다
감사합니다
2022-12-19
1270
글번호 164688
2wnwn 님에 의해서 삭제되었습니다.
2022-12-20
17
글번호 164687
답변완료
지표수식 변환 요청드립니다
트레이딩뷰 지표수식 변환 요청드립니다.
##
// RSI Past
//@version=5
indicator(title="RSI Past", shorttitle="RSI Past", overlay=false, precision=0)
// RSI input settings
rsiLength = input.int(14, title="Length", minval=2, group="RSI Settings")
rsiSource = input(close, title="Price", group="RSI Settings")
rsiOverbought = input.float(70, title="Overbought Threshold", group="RSI Settings")
rsiOversold = input.float(30, title="Oversold Threshold", group="RSI Settings")
// RSI input colors
color aboveColor = input.color(color.green, "Above 0 Color", group="Color Settings")
color belowColor = input.color(color.red, "Below 0 Color", group="Color Settings")
color zeroColor = input.color(color.black, "Zero Line Color", group="Color Settings")
var color plotColor = zeroColor
var int lastBullish = na
var int lastBearish = na
var float reading = na
rsiValue = ta.rsi(rsiSource, rsiLength)
if rsiValue < rsiOversold
lastBearish := bar_index
else if rsiValue > rsiOverbought
lastBullish := bar_index
if lastBullish and lastBearish
reading := lastBullish - lastBearish
if reading
if reading > 0
plotColor := aboveColor
else if reading < 0
plotColor := belowColor
else
plotColor := zeroColor
readingPlot = plot(reading, title="RSI Pass", color=plotColor, style=plot.style_area, linewidth=3)
2022-12-19
1336
글번호 164684