커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
6142
글번호 230811
답변완료
Data2 의 전일종가 데이터가 09시 1분까지는 전전일 종가를 입력받습니다.
안녕하세요! 항상 도움 많이 받고 있습니다. 감사합니다.
다름 아니고, 예스트레이더를 사용할 때, Data2나 Data3에서 전일종가를 입력받고 싶은데요.
그런데 09시 01분 전까지는 전일종가 데이터가 아니라 전전일 종가 데이터를 입력받습니다.
이거 수정할 수 있는 방법이 있을까요?
==================================================================
요약.
Data1의 CloseD(1)은 09시 01분 이전에도 전일종가를 정상적으로 입력 받는데,
Data3의 CloseD(1)인 Data3(CloseD(1))은 09시 01분 이전에는 전전일 종가를 입력받네요.
===================================================================
첨부 이미지 설명) 거래소 외국인 순매수금액
2024년 2월 5일 08:45부터
2024년 2월 2일 종가 데이터(전일종가)인 18,950 을 입력받고 싶은데,
2024년 2월 1일 종가 데이터(전전일종가)인 10,452 를 입력받고 있습니다.
2025-09-19
780
글번호 194147
2wnwn 님에 의해서 삭제되었습니다.
2025-09-19
49
글번호 194146
답변완료
검색식 부탁 드립니다
A= Disparity(Period2);
D=ValueWhen(1, crossup(A, 기준2) OR crossdown(A, 기준2) ,가격)
지표조건
period2 120
기준2 101
가격 (H+L)/2
주가가 D를 돌파했다 최근 7일사이 어느날에 종목 검색식 부탁드립니다
2025-09-19
343
글번호 194144
답변완료
종목검색식 요청드립니다.
당일 분봉에서 아래조건식을 만족했던 모든 종목을 검색하는 검색식으로 수정 부탁드리겠습니다. 그리고 1일전, 2일전, 3일전 등 n일전 종목검색도 가능하다면 부탁드리겠습니다. 항상 감사합니다.
* 예스트레이더 조건식
Input : PERIOD(20),N(5);
Var : 상승(False),하락(False),조건(False),조건1(False),TSF1(0),HV1(False),HV2(False),TH(0);
TsF1 = LRL(C,PERIOD)+LRS(C,PERIOD);
상승=TsF1>TsF1[1];
하락=TsF1<TsF1[1];
조건=CountIF(하락,N)==N && CountIF(상승[N],N)==N;
HV1=Highest(v,120)<=V;
HV2=Highest(v,240)<=V;
IF 조건 TheN
TH=TsF1[N];
조건1=Crossup(C,TH);
IF (조건1==True OR 조건1[1]==True) && (HV1 OR HV2) TheN
Find(1);
2025-09-19
329
글번호 194143
답변완료
종목검색식 요청드립니다.
아래 키움라인을 돌파하는 종목을 검색하는 검색식을 만들고 싶습니다. 도움 부탁드립니다.
* 키움수식라인 (조건 : 기간 20)
A = if(C > O, C, 0);
S = if(C > O, 1, 0);
AA = sum(A, 기간);
SS = sum(S, 기간);
if(AA == 0 or SS == 0, C(기간 - 1), AA / SS)
2025-09-19
316
글번호 194142
답변완료
지표 변환 부탁드립니다.
// 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/
// © LuxAlgo
//@version=5
indicator("Supply and Demand Visible Range [LuxAlgo]", overlay = true, max_boxes_count = 500, max_bars_back = 500)
//------------------------------------------------------------------------------
//Settings
//-----------------------------------------------------------------------------{
per = input.float(10., 'Threshold %', minval = 0, maxval = 100)
div = input.int(50, 'Resolution' , minval = 2, maxval = 500)
tf = input.timeframe('', 'Intrabar TF')
//Colors
showSupply = input(true ,'Supply        ', inline = 'supply', group = 'Style')
supplyCss = input(#2157f3, '' , inline = 'supply', group = 'Style')
supplyArea = input(true ,'Area' , inline = 'supply', group = 'Style')
supplyAvg = input(true ,'Average' , inline = 'supply', group = 'Style')
supplyWavg = input(true ,'Weighted' , inline = 'supply', group = 'Style')
showEqui = input(true ,'Equilibrium' , inline = 'equi' , group = 'Style')
equiCss = input(color.gray, '' , inline = 'equi' , group = 'Style')
equiAvg = input(true ,'Average' , inline = 'equi' , group = 'Style')
equiWavg = input(true ,'Weighted' , inline = 'equi' , group = 'Style')
showDemand = input(true ,'Demand    ' , inline = 'demand', group = 'Style')
demandCss = input(#ff5d00, '' , inline = 'demand', group = 'Style')
demandArea = input(true ,'Area' , inline = 'demand', group = 'Style')
demandAvg = input(true ,'Average' , inline = 'demand', group = 'Style')
demandWavg = input(true ,'Weighted' , inline = 'demand', group = 'Style')
//-----------------------------------------------------------------------------}
//UDT's
//-----------------------------------------------------------------------------{
type bin
float lvl
float prev
float sum
float prev_sum
float csum
float avg
bool isreached
type area
box bx
line avg
line wavg
//-----------------------------------------------------------------------------}
//Functions
//-----------------------------------------------------------------------------{
n = bar_index
get_hlv()=> [high, low, volume]
method set_area(area id, x1, top, btm, avg, wavg, showArea, showAvg, showWavg)=>
if showArea
id.bx.set_lefttop(x1, top)
id.bx.set_rightbottom(n, btm)
if showAvg
id.avg.set_xy1(x1, avg)
id.avg.set_xy2(n, avg)
if showWavg
id.wavg.set_xy1(x1, wavg)
id.wavg.set_xy2(n, wavg)
//-----------------------------------------------------------------------------}
//Main variables
//-----------------------------------------------------------------------------{
var max = 0.
var min = 0.
var x1 = 0
var csum = 0.
//Intrabar data
[h, l, v] = request.security_lower_tf(syminfo.tickerid, tf, get_hlv())
//Init on left bar
if time == chart.left_visible_bar_time
max := high
min := low
csum := volume
x1 := n
else //Accumulate
max := math.max(high, max)
min := math.min(low, min)
csum += volume
//-----------------------------------------------------------------------------}
//Set zones
//-----------------------------------------------------------------------------{
var supply_area = area.new(
box.new(na, na, na, na, na, bgcolor = color.new(supplyCss, 80))
, line.new(na, na, na, na, color = supplyCss)
, line.new(na, na, na, na, color = supplyCss, style = line.style_dashed))
var demand_area = area.new(
box.new(na, na, na, na, na, bgcolor = color.new(demandCss, 80))
, line.new(na, na, na, na, color = demandCss)
, line.new(na, na, na, na, color = demandCss, style = line.style_dashed))
var equi = line.new(na, na, na, na, color = equiCss)
var wequi = line.new(na, na, na, na, color = equiCss, style = line.style_dashed)
var float supply_wavg = na
var float demand_wavg = na
if time == chart.right_visible_bar_time
r = (max - min) / div
supply = bin.new(max, max, 0, 0, 0, 0, false)
demand = bin.new(min, min, 0, 0, 0, 0, false)
//Loop trough intervals
for i = 0 to div-1
supply.lvl -= r
demand.lvl += r
//Accumulated volume column
if not supply.isreached and showSupply and supplyArea
box.new(x1, supply.prev, x1 + int(supply.sum / csum * (n - x1)), supply.lvl, na
, bgcolor = color.new(supplyCss, 50))
if not demand.isreached and showDemand and demandArea
box.new(x1, demand.lvl, x1 + int(demand.sum / csum * (n - x1)), demand.prev, na
, bgcolor = color.new(demandCss, 50))
//Loop trough bars
for j = 0 to (n - x1)-1
//Loop trough intrabars
for k = 0 to (v[j]).size()-1
//Accumulate if within upper internal
supply.sum += (h[j]).get(k) > supply.lvl and (h[j]).get(k) < supply.prev ? (v[j]).get(k) : 0
supply.avg += supply.lvl * (supply.sum - supply.prev_sum)
supply.csum += supply.sum - supply.prev_sum
supply.prev_sum := supply.sum
//Accumulate if within lower interval
demand.sum += (l[j]).get(k) < demand.lvl and (l[j]).get(k) > demand.prev ? (v[j]).get(k) : 0
demand.avg += demand.lvl * (demand.sum - demand.prev_sum)
demand.csum += demand.sum - demand.prev_sum
demand.prev_sum := demand.sum
//Test if supply accumulated volume exceed threshold and set box
if supply.sum / csum * 100 > per and not supply.isreached
avg = math.avg(max, supply.lvl)
supply_wavg := supply.avg / supply.csum
//Set Box/Level coordinates
if showSupply
supply_area.set_area(x1, max, supply.lvl, avg, supply_wavg, supplyArea, supplyAvg, supplyWavg)
supply.isreached := true
//Test if demand accumulated volume exceed threshold and set box
if demand.sum / csum * 100 > per and not demand.isreached and showDemand
avg = math.avg(min, demand.lvl)
demand_wavg := demand.avg / demand.csum
//Set Box/Level coordinates
if showDemand
demand_area.set_area(x1, demand.lvl, min, avg, demand_wavg, demandArea, demandAvg, demandWavg)
demand.isreached := true
if supply.isreached and demand.isreached
break
if supply.isreached and demand.isreached and showEqui
//Set equilibrium
if equiAvg
avg = math.avg(max, min)
equi.set_xy1(x1, avg)
equi.set_xy2(n, avg)
//Set weighted equilibrium
if equiWavg
wavg = math.avg(supply_wavg, demand_wavg)
wequi.set_xy1(x1, wavg)
wequi.set_xy2(n, wavg)
break
supply.prev := supply.lvl
demand.prev := demand.lvl
//-----------------------------------------------------------------------------}
2025-09-19
1042
글번호 194141
답변완료
지표관련 문의 드립니다.
안녕하세요. 운영자님
아래 작성해 주신 수식을 수정을 좀 해야할 것 같아서 부탁드립니다.
보내주신 수식의 볼린저밴드 예측선인데, 제가 표현하고 싶은 것은
수식1 : 일반 볼린저밴드에서의 수평선 그리기 (그림에서는 수형선이 뒤쪽으로만 나오는데
앞쪽으로도 나올 수 있도록 부탁드립니다)
첨부된 그림에서와 같이 차트속성에 현재가를 수평선(녹색) 그리는 기능이 있는데
동일한 방식으로 그려기기을 원합니다.
수식2 : 볼린저밴드 예측선도 수식1과 동일한 방식으로 작성되기를 원합니다.
기본볼린저 밴드와 볼린저 밴드 예측선이 하나의 수식에 포함되기를 원하지 않습니다.
====================================================================================
안녕하세요
예스스탁입니다.
특정값을 차트에 수평으로 그리기 위해서는
추세선함수를 사용해야 하는데
추세선함수가 봉완성시에만 동작해서 마지막봉값은 출력하지 못합니다.
마지막완성봉의 값으로 출력하신다면 아래식 이용하시면 됩니다.
input : Period(20),dv(2);
input : 상단색(Red),하단색(Blue);
input : 상단긁기(1),하단굵기(1);
var : bbmd(0),SumSqrt(0),cnt(0),stdv(0);
var : bbup(0),bbdn(0);
bbmd = (C+AccumN(C,Period-1))/Period;
SumSqrt = (C-bbmd)^2;
For cnt = 0 To Period - 2
{
SumSqrt = SumSqrt + (C[cnt] - bbmd)^2;
}
Stdv = SquareRoot(SumSqrt / Period);
bbup = BBmd + stdv*dv;
bbdn = BBmd - stdv*dv;
Plot1(bbup,"상단");
Plot2(bbmd,"중단");
Plot3(bbdn,"하단");
//오른쪽으로 1봉 이동
FixPlotShift(1,1);
FixPlotShift(2,1);
FixPlotShift(3,1);
var : TL1(0),TL2(0);
TL_Delete(TL1);
TL_Delete(TL2);
TL1 = TL_New(sDate,sTime,BBup,NextBarSdate,NextBarStime,BBup);
TL2 = TL_New(sDate,sTime,BBdn,NextBarSdate,NextBarStime,BBdn);
TL_SetExtLeft(TL1,true);
TL_SetExtLeft(TL2,true);
TL_SetColor(TL1,상단색);
TL_SetColor(TL2,하단색);
TL_SetSize(TL1,상단긁기);
TL_SetSize(TL2,하단굵기);
2025-09-19
436
글번호 194140
답변완료
매수신호
안녕하세요
주간 일 중 5분선이 20선을 통과 할 때 매수, 매도 신호가 나오나
일 시작시 조건이 맞으면 8시 50분에 신호가 나옵니다.
날짜가 바뀌는 거와 상관없이 장시작 후 에만 신호가 나오게 수식 부탁합니다.
2025-09-19
270
글번호 194136
답변완료
종목검색식 부탁드립니다
1. 주봉 10이평을(단순) 몸통으로 돌파하고 양봉인
0봉전 ~10봉전의 모든종목 검색식 부탁드립니다
2. 주봉 10이평 기준(단순),
상.하 0.5% 에 있고(위아래) 양봉인 0봉전~10봉전 모든종목 검색식 부탁드려요.
2025-09-19
254
글번호 194131