커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
6177
글번호 230811
답변완료
검색식동작제대로안합니다.
input : nn(5),mm(150),bb(3),hh(6);
if DayIndex==0 Then
{
var1 = 0;
Var2 = 0;
Var3 = 0;
Var4=0;
Var5=0;
}
var1 = var1+m;
if DayIndex<=nn Then
{
if var1/100000000>=mm && (DayHigh/Bp-1)*100>=hh && (DayHigh/DayOpen-1)*100>=bb Then
{
Var2 = var1;
Var3 = DayHigh/Bp-1;
}
}
if LastBarOnChart==1 && DayVolume>0 && DateToJulian(CurrentDate) - DateToJulian(sDate) <=7 && DayHigh/Bp>1.04
Then
{
Find(int(var2/100000000)+Var3);
}
으로 1분봉 500봉으로 검색식을 돌리면 검색이제대로되지않습니다
오늘기준으로 검색하면 겔럭시아머니트리 검색결과값이 563.30 동양철관 167.09 갤럭시아에스엠 217.15 로
검색결과값이 나옵니다.
해당 검색식의 find 부분을 지표식에 넣어서 mess로 디버깅삼아 출력하면 제대로 값이 나오는데 왜 이런식으로나오는지궁금하니다.
저는 6분봉일때 그날 몸통이3퍼이상오르고 시가대비는 6퍼센트가올랐으면 그순간의 누적분봉거래대금을 결과값으로 보고싶은건데
결과값이보면 소수점 아래 보면 당일 하루종일의 최고가가 소수점에 나오고
분봉상 6번째봉이아닌 다른 봉의 누적 거래대금값이 누적되어서 계산된걸로나옵니다.
검색식이 제대로동작안하는것처럼보입니다
분명지표식으로 변환하면 문제없습니다 왜그런지 확인부탁드립니다.
2025-06-09
453
글번호 191556
답변완료
종목검색식 부탁드림니다.
항상 노고에 감사드림니다.
아래의 수식을 종목검색식으로 부탁드림니다.
1)
M=EAVG(C, 기간);
M-M(1);
Crossup(C, M)
지표변수
기간 200
2)
A=avg(c,Period)-avg(c,기간)*비율/100;//엔벨롭 하단
A1=sum(if(C-C(1)>0,C-C(1),0),Period)/sum(if(C-C(1)>0,C(1),C(1)-C),Period)*100;//RSI
A2=eavg(if(L(1)-L>0 && H-H(1)<L(1)-L,L(1)-L,0),Period)/eavg(max(max(H-L,abs(C(1)-H)),abs(C
(1)-L)),Period)*100; //DMI-
(L(1)<=A(1) OR L<=A) && (A1(1)<=30 OR A1<=30) && (A2(1)>30 OR A2>30) && C>0
지표변수
기간 20
비율 12
Period 14
2025-06-10
337
글번호 191555
답변완료
부틱드립니다
수고하십니다
아래수식을 예스로 부탁드립니다
//settings
length = input.int(14,minval = 2)
smoType1 = input.string('RMA','Method',options = ['EMA','SMA','RMA','TMA'])
src = input(close,'Source')
arsiCss = input(color_silver,'color',inline = 'rsicss')
autoCss = input(true,'Auto',inline = 'rsicss')
//signal line
smooth = input.int(14,minval = 1,group = 'Signal Line')
smoType2 = input.string('EMA','Method',options = ['EMA','SMA','RMA','TMA'], group = 'Signal Line')
signalCss = input( #ff5d00,'Color',group = 'Signal Line')
//OB/OS Style
obValue = input.FLoat(80,'Overbought',inline = 'ob', group = 'OB/OS Style')
obCss = input( #089981,'', inline = 'ob', group = 'OB/OS Style')
obAteaCss = input( color_new(#089981, 80),'',inline = 'ob', group = 'OB/OS Style')
osValue = input.FLoat(20, 'Oversold ',inline = 'os', group = 'OB/OS Style')
osCss = input( #f23645,'', inline = 'os', group = 'OB/OS Style')
osAreaCss = input( color_new(#f23645, 80),'',inline = 'os', group = 'OB/OS Style')
//Functions
ma(x, len, maType) =>
switch maType
'EMA' => ta.ema(x, len)
'SMA' => ta.sma(x, len)
'RMA' => ta.rma(x, len)
'TMA' => ta.sma(ta.sma(x, len), len)
//Augmented RSI
upper = ta.highest(src,length)
lower = ta.lowest(src,length)
r = upper - lower
d = src - src[1]
diff = upper > upper[1] ? r
: lower < lower[1] ? -r
: d
num = ma(diff, length,smoType1)
den = ma(math.abs(diff),length, smoType1)
arsi = num / den *50 + 50
signal = ma(arsi,smooth,smoType2)
//Plots
plot_rsi = plot(arsi,'Ultimate RSI'
,arsi > obvalue ? obCss
:arsi < osvalue ? osCss
:autoCss ? chart.fg_color : arsiCss)
plot(signal,'signal Line',signalCss)
//Levels
plot_up = plot(obvalue,color = na, editable = false)
plot_avg = plot(50, color = na, editable = false)
plot_dn = plot(osvalue, color = na, editable = false)
//OB-OS
fill(plot_rsi, plot_up, arsi > obvalue ? obAreaCss : na)
fill(plot_dn, plot_rsi, arsi < osvalue ? osAreaCss : na)
//Gradient
fill(plot_rsi, plot_avg, obvalue, 50, obAreaCss, color.new(chart.bg_color, 100))
fill(plot_avg, plot_rsi, 50, osvalue, color.new(chart.bg_color, 100),osAreaCss)
hline(obvalue,'Overbought')
hline(50,'Midline')
hline(osValue, 'Oversold')
//=== Supertrend 추가 ===
Periods = input.int(10, title ="ATR Period")
Multiplier = input.float(3.0, step=0.1,title ="ATR Multiplier")
changeATR = input.bool(true,title="change ATR Calculation Method ?")
atr2 = ta.sma(ta.tr, periods)
atr = changeATR ? ta.atr(Periods) : atr2
super_src = hl2
up = super_src - Multiplier * atr
up1 = nz(up[1], up)
up := close[1] > up1 ? math.max(up, up1) : up
dn = super_src + Multiplier * atr
dn1 = nz(dn[1], dn)
dn := close[1] < dn1 ? math.min(dn, dn1) : dn
trend = 1
trend := nz(trend[1], trend)
trend := trend == -1 and close > dn1 ? 1 : trend == 1 and close < up1 ? -1 : trend
plot(trend == 1 ? up : na, title ="up trend", style = plot.styie_linebr, 1
plot(trend == -1 ? dn : na, title ="down trend", style = plot.styie_linebr ,1
2025-06-09
492
글번호 191554
답변완료
진입시간 문의
if stime > 084500 and stime <= 151700 and 수식A Then
Buy();
이전까지는 상기와 같은 시간에 수식A 만족시 매수하는 공식으로 매매를 했는데
IM투자증권이 야간거래까지 진행이 되다보니
084500 ~ 익일 053700 까지 수식 A에 맞으면 매수를 하는 형태의 거래를 하고 싶습니다.
알려주시면 감사하겠습니다.
추가적으로 084500 ~ 익일053700까지 거래중 고점 저점은 동일적용하고 싶습니다.
ex) 기존 저점에서 -0.5포 하락시 손절(매수상황시)
ex) 기존 고점에서 +0.5포 상승시 손절(매도상황시)
오늘 장을 보니 야간장 들어서면 바로 야간장 기준으로 고/저 점이 바뀌는것 같아서요..
2025-06-09
377
글번호 191553
답변완료
변환 부탁드립니다
다음수식 종목검색 부탁드립니다
HV=Highestsince(1, date(3) != date, V);
A=Valuewhen(1, HV== V && C > 0, H);
B=Valuewhen(1, HV== V && C > 0, L);
AA=(A-B) * 2 / 4 + B;
A1=eavg(C, 5);
B1=eavg(C, 10);
X=(A1 - B1);
조건=A1 > B1 && X > X(1) && AA >= L && H(1) > H && L(1) < L
2025-06-09
336
글번호 191551
관리자에 의해 예스스팟 QnA로 이동되었습니다
2025-06-10
11
글번호 191544
답변완료
부탁드립니다
예스식으로 바꿀려고 하는데 도움 좀 받을수 있을까요?
AA = if( (h>Btm) and (L!=Btm), 1,if (BB, 1, 0));
HH = if (AA, H, highestsince(1,AA==1, H));
제생각엔 "highestsince(1,AA==1, H)"만 따로 떼서
if AA==1 Then
DD=H;
라고 하고 그자리에 DD를 넣어주고, 앞조건 if 는 iff 로 하면 될까요?
도움 주신 것 미리 감사 드립니다
2025-06-10
341
글번호 191538
답변완료
변환 부탁드립니다.
안녕하세요?
아래 트뷰 지표를 나름 변경해 보았습니다. 예스랭귀지에서 에러는 발생하지 않는데, 화면에 아무것도 안나오네요. 제가 만든 스크립트 무시하더라도 최대한 트뷰와 비슷하게 수정부탁드립니다.
== 변경 ==
Input: left(14), right(14), areaOpt(0);
Input: showTop(True), showBtm(True);
Var: ph(false), pl(false);
Var: ph_top(0), ph_btm(0), ph_vol(0);
Var: pl_top(0), pl_btm(0), pl_vol(0);
Var: i(0);
Var: ph_boxID(0), pl_boxID(0), ph_tlID(0), pl_tlID(0), ph_txtID(0), pl_txtID(0);
ph = swinghigh(1, High, left, right, 0) != -1;
pl = swinglow(1, Low, left, right, 0) != -1;
If ph == True and showTop == True then {
ph_top = High[right];
If areaOpt == 0 then
ph_btm = Max(Close[right], Open[right]);
else
ph_btm = Low[right];
// 거래량 누적(박스범위 내)
ph_vol = 0;
For i = right To left + right - 1 {
If (Low[i] < ph_top and High[i] > ph_btm) then
ph_vol = ph_vol + Volume[i];
}
// 기존 오브젝트 삭제
If ph_boxID != 0 then Box_Delete(ph_boxID);
If ph_tlID != 0 then TL_Delete(ph_tlID);
If ph_txtID != 0 then Text_Delete(ph_txtID);
ph_boxID = Box_New(
sDate[left + right - 1], sTime[left + right - 1], ph_top,
sDate[right], sTime[right], ph_btm
);
Box_SetColor(ph_boxID, rgb(246,79,8));
Box_SetFill(ph_boxID, True, 120, True);
// 수평선(피벗 구간 전체)
ph_tlID = TL_New(sDate[left + right - 1], sTime[left + right - 1], ph_top, sDate[right], sTime[right], ph_top);
TL_SetColor(ph_tlID, rgb(246,79,8));
TL_SetSize(ph_tlID, 2);
// 거래량 라벨(박스 좌상단에 표시)
ph_txtID = Text_New(sDate[left + right - 1], sTime[left + right - 1], ph_top, "V:" + NumToStr(ph_vol, 0));
Text_SetStyle(ph_txtID, 1, rgb(246,79,8));
}
If pl == True and showBtm == True then {
pl_top = Iff(areaOpt == 0, Min(Close[right], Open[right]), High[right]);
pl_btm = Low[right];
pl_vol = 0;
For i = right To left + right - 1 {
If (Low[i] < pl_top and High[i] > pl_btm) then
pl_vol = pl_vol + Volume[i];
}
If pl_boxID != 0 then Box_Delete(pl_boxID);
If pl_tlID != 0 then TL_Delete(pl_tlID);
If pl_txtID != 0 then Text_Delete(pl_txtID);
pl_boxID = Box_New(
sDate[left + right - 1], sTime[left + right - 1], pl_top,
sDate[right], sTime[right], pl_btm
);
Box_SetColor(pl_boxID, rgb(10,139,109));
Box_SetFill(pl_boxID, True, 120, True);
pl_tlID = TL_New(sDate[left + right - 1], sTime[left + right - 1], pl_btm, sDate[right], sTime[right], pl_btm);
TL_SetColor(pl_tlID, rgb(10,139,109));
TL_SetSize(pl_tlID, 2);
pl_txtID = Text_New(sDate[left + right - 1], sTime[left + right - 1], pl_btm, "V:" + NumToStr(pl_vol, 0));
Text_SetStyle(pl_txtID, 1, rgb(10,139,109));
}
== 트뷰 ==
//@version=5
indicator("예시"
, overlay = true
, max_lines_count = 500
, max_labels_count = 500
, max_boxes_count = 500)
//------------------------------------------------------------------------------
//Settings
//-----------------------------------------------------------------------------{
length = input(14, 'Period')
area = input.string('Wick only', 'Swing Range', options = ['Wick only', 'Full Bar'])
//Style
showTop = input(true, '저항', inline = 'top', group = 'Style')
topCss = input(#f64f08, '' , inline = 'top', group = 'Style')
topAreaCss = input(#ff52525c, 'Area', inline = 'top', group = 'Style')
showBtm = input(true, '지지', inline = 'btm', group = 'Style')
btmCss = input(#0a8b6d, '' , inline = 'btm', group = 'Style')
btmAreaCss = input(#00897b53, 'Area', inline = 'btm', group = 'Style')
labelSize = input.string('Tiny', 'Labels Size', options = ['Tiny', 'Small', 'Normal'], group = 'Style')
//-----------------------------------------------------------------------------}
//Functions
//-----------------------------------------------------------------------------{
n = bar_index
get_counts(condition, top, btm)=>
var count = 0
var vol = 0.
if condition
count := 0
vol := 0.
else
vol += low[length] < top and high[length] > btm ? volume[length] : 0
count += low[length] < top and high[length] > btm ? 1 : 0
[count, vol]
set_label(count, vol, x, y, css, lbl_style)=>
var label lbl = na
var label_size = switch labelSize
'Tiny' => size.tiny
'Small' => size.small
'Normal' => size.normal
target = count
if ta.crossover(target, 0)
lbl := label.new(x, y, str.tostring(vol, format.volume)
, style = lbl_style
, size = label_size
, color = #00000000
, textcolor = css)
if target > 0
label.set_text(lbl, str.tostring(vol, format.volume))
set_level(condition, crossed, value, count, vol, css)=>
var line lvl = na
target = count
if condition
if target[1] < 0[1]
line.delete(lvl[1])
else if not crossed[1]
line.set_x2(lvl, n - length)
lvl := line.new(n - length, value, n, value
, color = na)
if not crossed[1]
line.set_x2(lvl, n+3)
if crossed and not crossed[1]
line.set_x2(lvl, n)
line.set_style(lvl, line.style_dashed)
if target > 0
line.set_color(lvl, css)
set_zone(condition, x, top, btm, count, vol, css)=>
var box bx = na
target = count
if ta.crossover(target, 0)
bx := box.new(x, top, x + count, btm
, border_color = na
, bgcolor = css)
if target > 0
box.set_right(bx, x + count)
//-----------------------------------------------------------------------------}
//Global variables
//-----------------------------------------------------------------------------{
//Pivot high
var float ph_top = na
var float ph_btm = na
var bool ph_crossed = na
var ph_x1 = 0
var box ph_bx = box.new(na,na,na,na
, bgcolor = color.new(topAreaCss, 80)
, border_color = na)
//Pivot low
var float pl_top = na
var float pl_btm = na
var bool pl_crossed = na
var pl_x1 = 0
var box pl_bx = box.new(na,na,na,na
, bgcolor = color.new(btmAreaCss, 80)
, border_color = na)
//-----------------------------------------------------------------------------}
//Display pivot high levels/blocks
//-----------------------------------------------------------------------------{
ph = ta.pivothigh(length, length)
//Get ph counts
[ph_count, ph_vol] = get_counts(ph, ph_top, ph_btm)
//Set ph area and level
if ph and showTop
ph_top := high[length]
ph_btm := switch area
'Wick only' => math.max(close[length], open[length])
'Full Bar' => low[length]
ph_x1 := n - length
ph_crossed := false
box.set_lefttop(ph_bx, ph_x1, ph_top)
box.set_rightbottom(ph_bx, ph_x1, ph_btm)
else
ph_crossed := close > ph_top ? true : ph_crossed
if ph_crossed
box.set_right(ph_bx, ph_x1)
else
box.set_right(ph_bx, n+3)
if showTop
//Set ph zone
set_zone(ph, ph_x1, ph_top, ph_btm, ph_count, ph_vol, topAreaCss)
//Set ph level
set_level(ph, ph_crossed, ph_top, ph_count, ph_vol, topCss)
//Set ph label
set_label(ph_count, ph_vol, ph_x1, ph_top, topCss, label.style_label_down)
//-----------------------------------------------------------------------------}
//Display pivot low levels/blocks
//-----------------------------------------------------------------------------{
pl = ta.pivotlow(length, length)
//Get pl counts
[pl_count, pl_vol] = get_counts(pl, pl_top, pl_btm)
//Set pl area and level
if pl and showBtm
pl_top := switch area
'Wick only' => math.min(close[length], open[length])
'Full Bar' => high[length]
pl_btm := low[length]
pl_x1 := n - length
pl_crossed := false
box.set_lefttop(pl_bx, pl_x1, pl_top)
box.set_rightbottom(pl_bx, pl_x1, pl_btm)
else
pl_crossed := close < pl_btm ? true : pl_crossed
if pl_crossed
box.set_right(pl_bx, pl_x1)
else
box.set_right(pl_bx, n+3)
if showBtm
//Set pl zone
set_zone(pl, pl_x1, pl_top, pl_btm, pl_count, pl_vol, btmAreaCss)
//Set pl level
set_level(pl, pl_crossed, pl_btm, pl_count, pl_vol, btmCss)
//Set pl labels
set_label(pl_count, pl_vol, pl_x1, pl_btm, btmCss, label.style_label_up)
//-----------------------------------------------------------------------------}
2025-06-09
876
글번호 191537
회원 님에 의해서 삭제되었습니다.
2025-06-10
63
글번호 191535