커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1527
글번호 230811
답변완료
수식문의
안녕하세요?
첫번째 매수신호가 나왔을 때의 가격을 p1 이라고 기억함.
이후 두번째로 매수 신호가 나올 때의 가격을 p2 로 기억
지금 세번째로 매수 신호가 나왔고,
p1 > p2 > C
이면 매수 진입.
단, 1,2,3번째 매수 신호의 중간에 매도신호가 한번이라도 뜨면
처음부터 다시 카운트.
매도진입은 대칭적으로.
진입 후에는 5% 손절 또는 익절.
테스트용으로
매수신호는 스토캐스틱이 20선 크로스 업,
매도신호는 스토캐스틱이 80선 크로스다운
감사합니다.
감사합니다.
2025-08-27
195
글번호 193539
고박사122 님에 의해서 삭제되었습니다.
2025-08-27
51
글번호 193538
답변완료
검색식 부탁드려요 항상 감사합니다.
다음 수식은 음에서 양으로 바뀌는 종목을 찾으려고 만들었는데 일부 종목이 원래 양인 종목이 포함되서 나오는데 오류를 못찾겠습니다. 오류 수정 부탁드리겠습니다.
즉 전일까지는 상단선(음) 당일에 하단선(양)으로 변경되는 종목검색입니다.
추가로 당일에 양으로 바뀌는 선의 값이 일목 구름 상단에 있는 조건도 함께 부탁드립니다. 감사합니다.
Input : period(14), multiplier(3);
Var : src(0), alpha(0), source(0), AtrV(0),
upperBand(0), lowerBand(0), prevUpperBand(0), prevLowerBand(0),
prevRed(0);
If CurrentBar > 2 Then
{
// ── 지표식 동일: 지수 ATR
src = (H + L) / 2;
alpha = 1 / period;
source = Max(H - L, Max(Abs(H - C[1]), Abs(L - C[1])));
AtrV = alpha * source + (1 - alpha) * AtrV[1];
upperBand = src + multiplier * AtrV;
lowerBand = src - multiplier * AtrV;
prevUpperBand = upperBand[1];
prevLowerBand = lowerBand[1];
if (lowerBand > prevLowerBand) or (C[1] < prevLowerBand) then
lowerBand = lowerBand;
else
lowerBand = prevLowerBand;
if (upperBand < prevUpperBand) or (C[1] > prevUpperBand) then
upperBand = upperBand;
else
upperBand = prevUpperBand;
upperRaw[t-1] : upperRaw[t-2]
if (upperBand[1] < upperBand[2]) or (C[2] > upperBand[2]) then
prevRed = upperBand[1];
else
prevRed = upperBand[2];
if CrossUp(C, prevRed) Then
Find(1);
}
2025-08-27
217
글번호 193537
답변완료
수식좀 부탁드립니다
input : Period1(20),Period2(60),Period3(120); var1 = ma(C,Period1); var2 = ma(C,Period2); var3 = ma(c,Period3); if CrossUp(var1, var3) then buy(); if CrossUp(var1, var2) and var1 > var3 and var2 > var3 then buy(); } if Crossdown(var1, var3) then sell(); if Crossdown(var1, var2) and var1 < var3 and var2 < var3 then sell(); } 위의 수식에서 매수 신호 : - 매수신호 캔들 저가보다 - 저가가 작은 직전캔들 3개의 저가 라인과 수치좀 부탁드립니다 매도는 반대로 부탁드립니다
2025-08-27
197
글번호 193536
답변완료
지표 변환부탁드립니다.
// 시가, 고가, 저가 변수
openPrice = open
highPrice = high
lowPrice = low
// 매시간 정시에 해당하는 캔들인지 확인
isHourClose = (minute == 0)
// 양의 조건: 시가가 저가와 같고 저가가 더 이상 갱신되지 않는 경우
isPositive = isHourClose and (openPrice == lowPrice) and (lowPrice == ta.lowest(lowPrice, 1))
// 음의 조건: 시가가 고가와 같고 고가가 더 이상 갱신되지 않는 경우
isNegative = isHourClose and (openPrice == highPrice) and (highPrice == ta.highest(highPrice, 1))
// 텍스트를 저장할 변수
var string ssText = na
// 양의 텍스트 및 선 표시
if (isPositive)
ssText := str.tostring(openPrice)
label.new(bar_index, lowPrice - 1, text=ssText, style=label.style_label_up, color=color.green, textcolor=color.white, size=size.large, textalign=text.align_center)
line.new(bar_index[1], lowPrice, bar_index, lowPrice, color=color.red, width=1)
// 음의 텍스트 및 선 표시
if (isNegative)
ssText := str.tostring(openPrice)
label.new(bar_index, highPrice + 1, text=ssText, style=label.style_label_down, color=color.green, textcolor=color.white, size=size.large, textalign=text.align_center)
line.new(bar_index[1], highPrice, bar_index, highPrice, color=color.blue, width=1)
else
ssText := na // 조건이 충족되지 않으면 텍스트를 비움
2025-08-27
223
글번호 193535
답변완료
부탁드립니다^^
항상 도움 주심에 감사드립니다^^
매수 삼각형 신호 표시 : 현재 캔들의 종가가 360 이평 위에 있고, 현재 캔들의 위치는
양운이어야 하고 선행 일목 구름이 양운로 바뀔때 현재 캔들에 삼각형 신호를
매도 삼각형 신호 표시 : 위와 반대일 경우
지표 수식으로 부탁드립니다.^^
2025-08-27
226
글번호 193531
답변완료
거래량
늘 감사합니다.
1. data2 차트에 거래량이 1,000개 이상이 발생 할때마다,
각각의 봉에 시가 고가 저가 종가에 수평선을 긋는 수식,
굵기 색상 변경 가능 하게
2. 종가는 양봉이면 빨간색, 음봉이면 파란색입니다
3, 수평선은 당일 종가 까지만, 다음날은 다시 사작
4. 감사합니다.
2025-08-27
241
글번호 193528
답변완료
부탁 좀 드릴께요
항상 감사합니다.
아래 트뷰 지표를 변환하고자 합니다.
// This work is licensed under a Attribution-NonCommercial-ShareAlike 4.0 International (CC BY-NC-SA 4.0) https://creativecommons.org/licenses/by-nc-sa/4.0/
// © StratifyTrade
//@version=5
indicator("Liquidity Trendline With Signals [StratifyTrade]", "StratifyTrade - Liquidity Trendline With Signals", overlay = true, max_lines_count = 500, max_bars_back = 5000)
len = input.int (5, "Period",tooltip = "Lookback period", inline = "a", group = "SETTINGS")
cup = input.color(#0044ff, "", "" ,inline = "a", group = "SETTINGS")
cdn = input.color(#ff2b00, "", "" ,inline = "a", group = "SETTINGS")
space = input.float(2, "Padding",tooltip = "Padding distance", inline = "b", group = "SETTINGS", step = 0.1)
shs = input.bool (true, "Show Breakouts",inline = "z", group = "SETTINGS")
ph = ta.pivothigh(high, len, len)
pl = ta.pivotlow (low , len, len)
type store
float src
int n
type bar
float o = open
float h = high
float l = low
float c = close
int n = bar_index
float v = volume
type draw
line[] upln
line[] dnln
var store[] upbin = array.new<store>()
var store[] dnbin = array.new<store>()
var draw d = draw.new(array.new<line>(), array.new<line>())
bar b = bar.new()
atr = ta.atr(200)
method slope(line ln) =>
x = ln.get_x2() - ln.get_x1()
y = ln.get_y2() - ln.get_y1()
y / x
vol() =>
math.min(atr * 0.1, close * (0.1/100))
var bool broken = false
color active = na
bool plup = false
bool pldn = false
if ph
bool remove = false
var bool valid = false
upbin.unshift(store.new(b.h[len], b.n[len]))
if upbin.size() > 1
current = upbin.get(0)
before = upbin.get(1)
if current.src < before.src
if broken
valid := true
else
valid := false
if upbin.size() > 3
pastold = upbin.get(3)
pastcur = upbin.get(2)
now = upbin.get(1)
late = upbin.get(0)
if now.src < pastcur.src and now.src < pastold.src and late.src < pastcur.src and late.src < pastold.src
valid := true
else
valid := false
else
valid := false
if valid
d.upln.unshift(line.new(x1 = before.n, x2 = current.n, y1 = before.src, y2 = current.src, color = cdn))
d.upln.unshift(line.new(x1 = before.n, x2 = current.n, y1 = before.src - vol() * space, y2 = current.src - vol() * space, color = cdn))
ln = d.upln.get(1)
for i = 0 to (b.n - before.n)
slope = ln.slope()
ln.set_x2(b.n[i])
ln.set_y2(ln.get_y2() - slope)
if low[i] > ln.get_y2()
remove := true
break
if remove
d.upln.get(0).delete()
d.upln.get(1).delete()
d.upln .clear()
upbin .clear()
broken := true
else
d.upln.get(0).delete()
d.upln.get(1).delete()
d.upln .clear ()
d.upln.unshift(line.new(x1 = before.n, x2 = current.n, y1 = before.src, y2 = current.src, color = cdn))
d.upln.unshift(line.new(x1 = before.n, x2 = current.n, y1 = before.src - vol() * space, y2 = current.src - vol() * space, color = cdn))
linefill.new(d.upln.get(0), d.upln.get(1), color = color.new(cdn, 75))
upbin.clear()
broken := false
if d.upln.size() > 1
btm = d.upln.get(0)
top = d.upln.get(1)
if b.l > top.get_y2()
d.upln.clear()
broken := true
upbin.clear()
plup := true
if d.upln.size() > 1
slup = top.slope()
sldn = btm.slope()
top.set_x2(b.n)
top.set_y2(top.get_y2() + slup)
btm.set_x2(b.n)
btm.set_y2(btm.get_y2() + sldn)
if pl
bool remove = false
var bool valid = false
dnbin.unshift(store.new(b.l[len], b.n[len]))
if dnbin.size() > 1
current = dnbin.get(0)
before = dnbin.get(1)
if current.src > before.src
if broken
valid := true
else
valid := false
if dnbin.size() > 3
pastold = dnbin.get(3)
pastcur = dnbin.get(2)
now = dnbin.get(1)
late = dnbin.get(0)
if now.src > pastcur.src and now.src > pastold.src and late.src > pastcur.src and late.src > pastold.src
valid := true
else
valid := false
else
valid := false
if valid
d.dnln.unshift(line.new(x1 = before.n, x2 = current.n, y1 = before.src, y2 = current.src , color = cup))
d.dnln.unshift(line.new(x1 = before.n, x2 = current.n, y1 = before.src + vol() * space, y2 = current.src + vol() * space, color = cup))
ln = d.dnln.get(1)
for i = 0 to (b.n - before.n)
slope = ln.slope()
ln.set_x2(b.n[i])
ln.set_y2(ln.get_y2() - slope)
if high[i] < ln.get_y2()
remove := true
break
if remove
d.dnln.get(0).delete()
d.dnln.get(1).delete()
d.dnln .clear ()
dnbin .clear ()
broken := true
else
d.dnln.get(0).delete()
d.dnln.get(1).delete()
d.dnln .clear ()
d.dnln.unshift(line.new(x1 = before.n, x2 = current.n, y1 = before.src, y2 = current.src, color = cup))
d.dnln.unshift(line.new(x1 = before.n, x2 = current.n, y1 = before.src + vol() * space, y2 = current.src + vol() * space, color = cup))
linefill.new(d.dnln.get(0), d.dnln.get(1), color = color.new(cup, 75))
dnbin.clear()
broken := false
if d.dnln.size() > 1
btm = d.dnln.get(0)
top = d.dnln.get(1)
if b.h < btm.get_y2()
d.dnln.clear()
broken := true
dnbin.clear()
pldn := true
if d.dnln.size() > 1
slup = top.slope()
sldn = btm.slope()
top.set_x2(b.n)
top.set_y2(top.get_y2() + slup)
btm.set_x2(b.n)
btm.set_y2(btm.get_y2() + sldn)
plotshape(pldn and shs ? b.h[1] : na, "Breaking Down", shape.triangledown, location = location.abovebar, color = cdn , offset = -1, size = size.tiny)
plotshape(plup and shs ? b.l[1] : na, "Breaking Up" , shape.triangleup , location = location.belowbar, color = cup, offset = -1, size = size.tiny)
2025-08-27
459
글번호 193527
답변완료
사용자함수 질문입니다.
안녕하십니까 선생님?
다름이 아니오라
예스트레이더코인에서
1. 갭 오픈 시 체결가
롱 포지션에서 **타겟(AtLimit)**을 다음 봉 시가가 뛰어넘어 개장했을 때, 체결가는 시가로 집계되나요, 아니면 타겟가로 집계되나요?
2. 호가단위(틱) 스냅 적용 위치
판정(AtLimit/AtStop 비교) 단계에서도 호가단위로 라운딩해 비교하나요, 아니면 원시 실수값으로 비교하고 주문 집행 시점에만 호가단위 스냅이 적용되나요? 업비트처럼 가격대별 호가단위도 엔진이 자동 반영하는지 궁금합니다.
항상 감사합니다 선생님
좋은 하루 되십시오
2025-08-27
237
글번호 193526