커뮤니티

예스랭귀지 Q&A

글쓰기

[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내

안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
프로필 이미지
예스스탁
2026-02-27
1283
글번호 230811
지표
답변완료

도음을 청합니다.

93443 관련입니다. 번거롭게 해 드려 죄송합니다. 아래 sum데이터에 고점과 저점 Plot를 추가해주시고요 Plot2 - Plot7 까지의 피보나치비율을 sum(고점-(고점-저점)*비율로 산정해주세요 즉 고점과 저점을 기준으로 피보나치비율 Plot을 그리기를 원합니다. 도와 주심에 다시한번감사드립니다. 꾸벅 ========================================================= var : v1(0),sc(0),v2(0),sum(0); v1 = data1(Upvol-DownVol); SC = (C-O)/(H-L); v2 = SC*v; if Bdate != Bdate[1] Then sum = 0; sum = sum + (v1+v2)/2; if CurrentDate == sDate Then { Plot1(sum); Plot2(sum*0.25,"25%"); Plot3(sum*0.382,"38.2%"); Plot4(sum*0.5,"50%"); Plot5(sum*0.51,"51%"); Plot6(sum*0.618,"61.8%"); Plot7(sum*0.75,"75%"); } PlotBaseLine1(0,"기준라인 0"); =========================================
프로필 이미지
포보스
2025-07-08
221
글번호 192342
지표
답변완료

오류인지 확인 부탁드립니다

안녕하세요 담당자님 해당 시스템을 60/120/180/240분봉에 적용하는 경우 2018.10~2019년에 거래가 전혀 안되는 시기가 있습니다. 그 외 시간봉은 괜찮습니다 (일봉, 360분봉 등) 로직이나 가격 움직임을 봤을때 거래가 되어야하는데, 한번 확인 부탁드립니다. 감사합니다. Input:Period(10); Vars:ll(0),hh(0); ll = lowest(L,Period); hh = highest(H,Period); If MarketPosition == 0 and CrossUp(C,hh[1]) Then Buy("Buy",AtMarket,DEf,1); // STOP LOSS input:PTMult(1); var:AT(0); AT = ATR(14); If MarketPosition == 1 and Close >= (EntryPrice - (PTMult*AT[BarsSinceEntry])) Then ExitLong("PT",AtMarket); // PROFIT TAKING Input:PT(1); If MarketPosition == 1 Then SetStopProfittarget(PT,PercentStop);
프로필 이미지
sewzie
2025-07-08
202
글번호 192336
시스템
답변완료

수식문의드려요

안녕하세요. 만기일 관련해서 필요한 지표를 찾아보던중 답변된 내용이 있어 해당수식을 사용해보았는데, 만기일에 선표시는 잘되나 각만기일에 해당하는 고저폭을 계산하는 부분이 제대로 되지않아 해당부분을 수정해주셨으면 좋겠습니다. 옵션만기일, 선물만기일, 위클리만기일에서 해당 구간의 최고값과 최저값의 폭을 표시 할 수 있도록 수정해주세요. 그리고 두번째로 첨부하는 코드는 잔존만기일 계산인데, 이것을 분기별 3째주 금요일을 기준으로 계산되게 수정부탁드립니다. ------------------- 1번 코드 --------------------- var : month(0),nday(0),week(0); var : OX(False),OH(0),OL(0),OTL(0),OTX(0); var : FX(false),FH(0),FL(0),FTL(0),FTX(0); var : WOX(False),WOH(0),WOL(0),WOTL(0),WOTX(0); month = int(date/100)-int(date/10000)*100; nday = date - int(date/100)*100; Week = DayOfWeek(date); #옵션만기 if nday >= 8 and nday <= 14 and week == 4 Then { OX = true; } Else OX = False; if Bdate != Bdate[1] Then { if OX == False and OX[1] == true Then { OH = h; OL = L; } } if OH > 0 and H > OH Then OH = H; if OL > 0 and L < OL Then OL = L; if OX == true and sTime >= 150000 and sTime[1] < 150000 then { OTL = TL_New(sDate,sTime,0,sDate,sTime,9999999); TL_SetColor(OTL,RED); OTX = Text_New(sDate,sTime,H,NumToStr(OH-OL,2)); Text_SetColor(OTX,Red); Text_SetStyle(OTX,2,1); } #선물만기 if Month%3 == 0 and nday >= 8 and nday <= 14 and week == 4 Then { FX = true; } Else FX = false; if Bdate != Bdate[1] Then { if FX == False and FX[1] == true Then { FH = h; FL = L; } } if FH > 0 and H > FH Then FH = H; if FL > 0 and L < FL Then FL = L; if FX == true and sTime >= 150000 and sTime[1] < 150000 then { FTL = TL_New(sDate,sTime,0,sDate,sTime,9999999); TL_SetColor(FTL,BLUE); FTX = Text_New(sDate,sTime,H,NumToStr(FH-FL,2)); Text_SetColor(FTX,BLUE); Text_SetStyle(FTX,2,1); } #위클리옵션만기 if OX == False and week == 4 Then { WOX = true; } Else WOX = false; if Bdate != Bdate[1] Then { if WOX == False and WOX[1] == true Then { WOH = h; WOL = L; } } if WOH > 0 and H > WOH Then WOH = H; if WOL > 0 and L < WOL Then WOL = L; if WOX == true and sTime >= 150000 and sTime[1] < 150000 then { WOTL = TL_New(sDate,sTime,0,sDate,sTime,9999999); TL_SetColor(WOTL,Green); WOTX = Text_New(sDate,sTime,H,NumToStr(WOH-WOL,2)); Text_SetColor(WOTX,Green); Text_SetStyle(WOTX,2,1); } ------------------2번 코드 ------------------------ Var : Year(0),Month(0),ndate1(0),ndate2(0); var : cnt(0),count1(0),count2(0); var : XD1(0),XD2(0),Xdate(0),remain(0); Year = Floor(sDate / 10000)*10000; month = Floor(FracPortion(sdate/10000)*100)*100; ndate1 = year+month+1; if Month+100 <= 1200 Then ndate2 = year+(month+100)+1; Else ndate2 = (year+10000)+100+1; count1 = 0; count2 = 0; for cnt = 0 to 15 { if dayofweek(ndate1+cnt) == 4 Then { count1 = count1+1; if count1 == 2 Then { XD1 = ndate1+cnt; } } if dayofweek(ndate2+cnt) == 4 Then { count2 = count2+1; if count2 == 2 Then { XD2 = nDate2+cnt; } } } if sDate <= XD1 Then { Xdate = XD1; } Else { Xdate = XD2; } if Xdate > 0 Then { remain = DateToJulian(Xdate)-DateToJulian(sDate); Plot1(remain); }
프로필 이미지
oni
2025-07-07
316
글번호 192332
지표

장대박 님에 의해서 삭제되었습니다.

프로필 이미지
장대박
2025-07-07
39
글번호 192331
종목검색
답변완료

수식 부탁드립니다

다음 트레이딩뷰 수식을 아무리 변환해도 이상하게 표시되어 부탁드리게 되었씁니다. 미리 감사드립니다. //@version=5 indicator('Chandelier Exit[everget]', shorttitle='CE', overlay=true) var string calcGroup = 'Calculation' length = input.int(title='ATR Period', defval=22, group=calcGroup) mult = input.float(title='ATR Multiplier', step=0.1, defval=3.0, group=calcGroup) useClose = input.bool(title='Use Close Price for Extremums', defval=true, group=calcGroup) var string visualGroup = 'Visuals' showLabels = input.bool(title='Show Buy/Sell Labels', defval=true, group=visualGroup) highlightState = input.bool(title='Highlight State', defval=true, group=visualGroup) var string alertGroup = 'Alerts' awaitBarConfirmation = input.bool(title="Await Bar Confirmation", defval=true, group=alertGroup) atr = mult * ta.atr(length) longStop = (useClose ? ta.highest(close, length) : ta.highest(length)) - atr longStopPrev = nz(longStop[1], longStop) longStop := close[1] > longStopPrev ? math.max(longStop, longStopPrev) : longStop shortStop = (useClose ? ta.lowest(close, length) : ta.lowest(length)) + atr shortStopPrev = nz(shortStop[1], shortStop) shortStop := close[1] < shortStopPrev ? math.min(shortStop, shortStopPrev) : shortStop var int dir = 1 dir := close > shortStopPrev ? 1 : close < longStopPrev ? -1 : dir var color longColor = color.green var color shortColor = color.red var color longFillColor = color.new(color.green, 90) var color shortFillColor = color.new(color.red, 90) var color textColor = color.new(color.white, 0) longStopPlot = plot(dir == 1 ? longStop : na, title='Long Stop', style=plot.style_linebr, linewidth=2, color=color.new(longColor, 0)) buySignal = dir == 1 and dir[1] == -1 plotshape(buySignal ? longStop : na, title='Long Stop Start', location=location.absolute, style=shape.circle, size=size.tiny, color=color.new(longColor, 0)) plotshape(buySignal and showLabels ? longStop : na, title='Buy Label', text='Buy', location=location.absolute, style=shape.labelup, size=size.tiny, color=color.new(longColor, 0), textcolor=textColor) shortStopPlot = plot(dir == 1 ? na : shortStop, title='Short Stop', style=plot.style_linebr, linewidth=2, color=color.new(shortColor, 0)) sellSignal = dir == -1 and dir[1] == 1 plotshape(sellSignal ? shortStop : na, title='Short Stop Start', location=location.absolute, style=shape.circle, size=size.tiny, color=color.new(shortColor, 0)) plotshape(sellSignal and showLabels ? shortStop : na, title='Sell Label', text='Sell', location=location.absolute, style=shape.labeldown, size=size.tiny, color=color.new(shortColor, 0), textcolor=textColor) midPricePlot = plot(ohlc4, title='', style=plot.style_circles, linewidth=0, display=display.none, editable=false) longStateFillColor = highlightState ? dir == 1 ? longFillColor : na : na shortStateFillColor = highlightState ? dir == -1 ? shortFillColor : na : na fill(midPricePlot, longStopPlot, title='Long State Filling', color=longStateFillColor) fill(midPricePlot, shortStopPlot, title='Short State Filling', color=shortStateFillColor)
프로필 이미지
고도산
2025-07-07
278
글번호 192330
지표
답변완료

문의드립니다.

var : AA(False), BB(False); var : T(0), B(0); var1 = ma(C, 10); if sDate != sDate[1] and sTime >= 90000 Then { T = 0; B = 0; } B = B + 1; AA = DayOpen >= 5000 and DayOpen <= 6000; if AA and B >= 2 and CrossUp(C, var1) Then find(1); 이게...목적은 9시1분부터 검색되게 하는건데요... 실행하면, 9시, 1초,2초,3초에 검색됩니다... 그때는 검색되면 안되는데... 이유가 뭔지, 뭐를 수정해야 하는지, 부탁드립니다... 그리고... var : AA(False), BB(False); var : T(0), B(0); if sDate != sDate[1] and sTime >= 90000 Then { T = 0; B = 0; } B = B + 1; AA = DayOpen >= 5000 and DayOpen <= 15000; BB = DayOpen >= DayClose[1] and DayOpen <= DayClose[1] * 1.06; if AA and C >= DayHigh*0.998 Then find(1); 이게...실행하면, 10분쯤에, TypeError : undefined ....라고 메세지가 나오고 그 다음과정이 실행이 안됩니다... 이유를 알고싶습니다... 항상 감사하게 생각하고 있습니다...ㅎ
프로필 이미지
시온사랑
2025-07-07
254
글번호 192329
종목검색
답변완료

수식수정바랍니다

안녕하세요 아래 vwap 수식을 데이터2 로 사용할수있게 수식종 수정바랍니다 var : sum(0),VWAP(0),PreVWAP(0); if date != date[1] Then{ sum = 0; PreVWAP = VWAP; } sum = sum+((H+L+C)/3*v); VWAP = sum/DayVolume; plot1(VWAP,"Volume-Weighted Average Price"); plot2(PreVWAP,"전일"); 수고하세요
프로필 이미지
바닥차기
2025-07-07
286
글번호 192328
지표
답변완료

수식 부탁합니다

1. 1번 지표 S=(O-avg(L,20))/stdev(L,20); valuewhen(1,crossup(S,0),C); 2. 2번 지표 중최고가=최고값(고가,20); 중최저가=최저값(저가,20); 경계=(중최고가+중최저가)/2-(중최고가-중최저가)+배분1; 경계1=crossup(종가,경계)&&종가>시가+배분2; 경계2=crossdown(C,경계); 기준봉=valuewhen(1,경계1 or 경계2,시가); 기준봉1=crossup(종가,기준봉); 기준봉2=crossdown(종가,기준봉); 결과기준=valuewhen(1,기준봉1 or 기준봉2,시가); 결과기준1=crossup(종가,결과기준); 결과기준2=crossdown(종가,결과기준); valuewhen(1,결과기준1 or 결과기준2,시가) 위의 키움수식 지표 변환 부탁합니다
프로필 이미지
미래테크
2025-07-07
286
글번호 192327
지표

사공하늘 님에 의해서 삭제되었습니다.

프로필 이미지
사공하늘
2025-07-07
53
글번호 192326
검색