커뮤니티
예스랭귀지 Q&A
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1326
글번호 230811
사공하늘 님에 의해서 삭제되었습니다.
2025-04-04
146
글번호 189838
답변완료
수식문의입니다
주가의 위치(수준)를 제한하기 위한 조건수식을 위한 것입니다
120H = Highest(H,120) ;
120L = Lowest(L,120) ;
60H = Highest(H,60) ;
60L = Lowest(L,60) ;
Condition1 >
120봉의 최고가가 120봉의 최저가보다 먼저 발생된 경우(주가하락추세상태이거나 최저가후 일정수준의 상승상태인 경우)이면서 60봉의 최고가가 60봉의 최저가보다 먼저 발생된 경우라면 현재의 주가위치는 120봉의 최고가와 최저가의 38%이하이어야 한다는 조건수식
Condition2 >
120봉의 최고가가 120봉의 최저가보다 먼저 발생된 경우(주가하락추세상태이거나 최저가후 일정수준의 상승상태인 경우)이면서 60봉의 최고가가 60봉의 최저가보다 나중에(최근에) 발생된 경우라면-즉 상승추세로의 전환으로 단기 상승이 많이 발생된 상태- 현재의 주가위치는 120봉의 최고가와 최저가의 50%이하이어야 한다는 조건수식
2025-04-03
316
글번호 189837
답변완료
문의드립니다.
해외선물에서 20이평선을 기준으로 첫 봉이 종가상 20이평선을 돌파한 후
봉중에서 20이평선과 50틱 이상 차이가 나면 종가까지 기다리지 않고
즉시 매수신호가 나오게 하고 싶습니다.
매도신호는 그 반대입니다.
미리 노고에 감사드립니다.
2025-04-04
330
글번호 189836
답변완료
검색식 부탁 드려요
*역배열 종목 검색식 부탁 드려요
첫번째배열 밑에서 60 120 240 (지수)
두번째배열 밑에서 120 60 240 (지수)
세번째배열 밑에서 120 240 480 (지수)
위의 세가지 배열을 같이 합쳐서 "1개의 검색식"으로 구현 할수 있도록 부탁드려요
2025-04-03
354
글번호 189835
답변완료
질문드리겠습니다
안녕하세요 질문 2가지 부탁드립니다
질문1)
text_new 관련해서 질문드립니다
현재 메인차트 하단에 거래대금 지표를 따로 표시를 했는데요
text 함수로 봉 마다 거래대금 값 (var33 의 값) 을 나타내려고 합니다
텍스트 위치는 막대 (막대차트로 표현) 상단보다 조금 높은 위치로 해주세요
메인차트가 아니라 분리된 하단 차트에 나타내고 싶습니다
질문2)
수식에서 cc 배열 값을 연결하는 추세선 ttl2 배열을 만들어 주셨으면 합니다
cc 의 전값이 (cc[1]) 이 다음값 cc[0] 을 연결하는 추세선을 최근 "10개 까지만 보이게" 부탁합니다
수식은 질문1, 질문2 용으로 각각 올렸습니다
질문1 수식 =
var : cnt(0), sum1(0), sumi1(0),summ(0),tt(0),hh(0),ll(0),tl(0),tl1(0),tx1(0);
var: sum2(0),sumi2(0),sumaa(0);
var : t(0),StartBarIndex(0),dd(0),d1(0),d2(0),ee(0),e1(0),e2(0);
Array : ii[50](0),aa[50](0),bb[50](0),cc[50](0),vv[150](0),ttl[30](0);
Var33=(floor(Money/100000000/10)*10);
if Bdate != Bdate[1] Then
DD = DD+1;
#H>vi(1)*0.95 h>l*1.07
if h>min(l,l[1])*1.08 Then
{
d1 = dd;
d2 = d1[1];
#if d1 >= d2+1 Then
#if d2 == 0 or (d2 > 0 and d1 >= d2+3) Then
if d2 == 0 or (d2 > 0 and d1 >= d2+5) Then
{
var1 = Index;
Var2 = var1[1];
Var3= Var2[1];
sum1=0;
sumi1=0;
summ=0;
For cnt = 1 to (var1-Var2)
{
sum1=sum1+h[cnt];
sumi1=sumi1+1;
summ=summ+Var33[cnt];
}
value1=sum1/sumi1;
For cnt = 0 to 150
{
vv[cnt]=0;
}
For cnt = 1 to (var1-Var2)
{
vv[cnt-1]=h[cnt];
}
Plot12(summ,"Money",Orange,Def,1);
tx1=text_new(sDate,sTime,l,"");
}
}
질문2 수식=
var : cnt(0), sum1(0), sumi1(0),summ(0),tt(0),hh(0),ll(0),tl(0),tl1(0);
var: sum2(0),sumi2(0),sumaa(0);
var : t(0),StartBarIndex(0),dd(0),d1(0),d2(0),ee(0),e1(0),e2(0);
Array : ii[50](0),aa[50](0),bb[50](0),cc[50](0),vv[150](0),ttl[30](0);
if Bdate != Bdate[1] Then
DD = DD+1;
if h>min(l,l[1])*1.08 Then
{
d1 = dd;
d2 = d1[1];
#if d1 >= d2+1 Then
#if d2 == 0 or (d2 > 0 and d1 >= d2+3) Then
if d2 == 0 or (d2 > 0 and d1 >= d2+5) Then
{
var1 = Index;
Var2 = var1[1];
Var3= Var2[1];
sum1=0;
sumi1=0;
tl=TL_NEW(sDatE,sTimE,100,sDatE,sTimE,999999);
TL_SetSize(tl,0);
TL_SetColor(tl,Gray);
For cnt = 1 to (var1-Var2)
{
sum1=sum1+h[cnt];
sumi1=sumi1+1;
}
value1=sum1/sumi1;
For cnt = 0 to 150
{
vv[cnt]=0;
}
For cnt = 1 to (var1-Var2)
{
vv[cnt-1]=h[cnt];
}
Var20=Money/100000000;
if Var20>30 Then
{
For cnt = 49 DownTo 1
{
cc[cnt]= cc[cnt-1];
}
cc[0]=value1*0.666;
# Plot11(cc[0],"hma",Red,Def,1);
}
For cnt = 30 DownTo 1
{
ttl[cnt] =ttl[cnt-1];
}
TL_SetExtRight(ttl[10],False);
ttl[0]=tl_new(sDate,sTime,cc[0],NextBarSdate,NextBarStime,CC[0]);
TL_SetSize(ttl[0],1);
TL_SetExtRight(ttl[0],true);
}
}
Else
{
if CC[0] > 0 Then
TL_SetEnd(ttl[0],sDate,sTime,CC[0]);
}
2025-04-04
400
글번호 189834
잔차 님에 의해서 삭제되었습니다.
2025-04-03
4
글번호 189833
답변완료
문의 드립니다.
안녕하세요 ~
아래의 매수선을 돌파하는 검색식 부탁 드립니다.
A=highest(h,3);
B=Lowest(L,3);
D=(A+B)/2+(A-B)*0.382;
d1=crossup(c,D)&& c>o*1.02;
d2=crossdown(c,D);
E=valuewhen(1, d1 or d2, o);
e1=crossup(c,E);
e2=crossdown(c,E);
R=valuewhen(1, e1 or e2, o);
r1=crossup(c,R);
r2=crossdown(c,R);
S=valuewhen(1, r1 or r2, o);
T=wavg(S,2)*1.0062;
wavg(T,2)
감사합니다.
2025-04-03
309
글번호 189832
답변완료
하이킨아시
input : MaPeriod(2),MaPeriod2(1);
var : maOpen(0),maClose(0),maLow(0),maHigh(0);
var : haOpen(0),haClose(0),haLow(0),haHigh(0);
var : ExtMapBuffer1(0),ExtMapBuffer2(0),ExtMapBuffer3(0),ExtMapBuffer4(0);
Array : ExtMapBuffer5[100](0),ExtMapBuffer6[100](0),ExtMapBuffer7[100](0),ExtMapBuffer8[100](0);
var : r(0),g(0),b(0), TL(0),t(0),tx(0);
var : ii(0),cnt(0);
var : sum1(0),sum2(0),sum3(0),sum4(0),csum(0);
var : maOpen1(0),maClose1(0),maLow1(0),maHigh1(0);
var : WMA1(0),WMA2(0),WMA3(0),WMA4(0);
if Bdate != Bdate[1] Then
{
For cnt = 99 DownTo 1
{
ExtMapBuffer5[cnt] = ExtMapBuffer5[cnt-1];
ExtMapBuffer6[cnt] = ExtMapBuffer6[cnt-1];
ExtMapBuffer7[cnt] = ExtMapBuffer7[cnt-1];
ExtMapBuffer8[cnt] = ExtMapBuffer8[cnt-1];
}
ii = ii +1;
maOpen1 = maOpen[1];
maClose1 = maClose[1];
maLow1 = maLow[1];
maHigh1 = maHigh[1];
}
if ii == 0 Then
{
maOpen=dayOpen;
maClose=dayClose;
maLow=dayLow;
maHigh=dayHigh;
}
Else
{
maOpen=(maOpen1*(MAperiod-1)+dayOpen)/MAPeriod;
maClose=(maClose1*(MAperiod-1)+dayClose)/MAPeriod;
maLow=(maLow1*(MAperiod-1)+dayLow)/MAPeriod;
maHigh=(maHigh1*(MAperiod-1)+dayHigh)/MAPeriod;
haOpen=(ExtMapBuffer5[1]+ExtMapBuffer6[1])/2;
haClose=(maOpen+maHigh+maLow+maClose)/4;
haHigh=Max(maHigh, Max(haOpen, haClose));
haLow=Min(maLow, Min(haOpen, haClose));
if (haOpen<haClose) then
{
r=255;
g=10;
b=0;
ExtMapBuffer7[0]=haLow;
ExtMapBuffer8[0]=haHigh;
t = 1;
}
else
{
r=0;
g=191;
b=255;
ExtMapBuffer7[0]=haHigh;
ExtMapBuffer8[0]=haLow;
t = -1;
}
ExtMapBuffer5[0]=haOpen;
ExtMapBuffer6[0]=haClose;
if ExtMapBuffer5[maPeriod2-1] > 0 Then
{
Sum1 = 0;
Sum2 = 0;
Sum3 = 0;
Sum4 = 0;
CSum = 0;
For cnt = 0 To maPeriod2 - 1
{
Sum1 = Sum1 + ExtMapBuffer7[cnt] * (maPeriod2 - cnt);
Sum2 = Sum2 + ExtMapBuffer8[cnt] * (maPeriod2 - cnt);
Sum3 = Sum3 + ExtMapBuffer5[cnt] * (maPeriod2 - cnt);
Sum4 = Sum4 + ExtMapBuffer6[cnt] * (maPeriod2 - cnt);
CSum = CSum + maPeriod2 - cnt;
}
ExtMapBuffer1 = Sum1/CSum;
ExtMapBuffer2 = Sum2/CSum;
ExtMapBuffer3 = Sum3/CSum;
ExtMapBuffer4 = Sum4/CSum;
plot1(ExtMapBuffer1);
plot2(ExtMapBuffer2);
plot3(ExtMapBuffer3);
plot4(ExtMapBuffer4);
}
}
지난번 일봉을 분봉 답변해 주신건데요.타주기 60분봉를 5분봉에 그리고 싶어서 해봤는데 다른 값이 나와 문의 합니다.
2025-04-03
427
글번호 189831
답변완료
예스스팟 자동매수 시 주문가격 0원 증상 문의 드립니다.
감사합니다.
추가적으로 질문을 드리고 싶습니다.
제가 서적을 참조해서 작성해놓은 예스스팟식으로 자동 매수 매도 주문을 해놓으니까
캡쳐된 사진처럼 주문가격이 '0원'인데 혹시 이게 왜 이럴까요?ㅠㅠ
아래 코드 보시고 검토가 가능하실지 문의 드립니다.
시험 매매 돌려놓은 것입니다.
저는 일단 1주씩 '매수조건'으로 검색이 되는 즉시 시장가 매수
이후 '매도조건'일 경우 자동 매도가 되게 구현을 하고 싶습니다.
초보적인 질문을 계속 드려서 죄송합니다.
var timer5 = 2; // 2초
var 매수금 = 100000;
var OrderList = [];
var MKList = [];
var req;
var 종목제한수 = 10;
var Search;
function Main_OnStart()
{
Main.SetTimer(1, timer5 * 1000);
MKList = [];
Search = 1;
}
function Main_OnTimer(nEventID)
{
var d = new Date();
YYYYMMDD = d.getFullYear() * 10000 + (d.getMonth() + 1) * 100 + d.getDate();
HHMMSS = d.getHours() * 10000 + d.getMinutes() * 100 + d.getSeconds();
if (nEventID == 1 && HHMMSS > 090000 && HHMMSS < 151800)
{
Main.MessageList(Search);
if (Search == 1)
{
Main.ReqPowerSearch("매수조건");
}
else
{
Main.ReqPowerSearch("매도조건");
}
Main.KillTimer(1);
}
if (nEventID == 2)
{
Main.ReqMarketData(OrderList[req]);
Main.KillTimer(2);
}
}
function Main_OnRcvItemList(aItemList, nCount)
{
Main.MessageList(nCount);
OrderList = [];
if (Search == 1)
{
if (nCount >= 1)
{
if (MKList.length == 0)
{
OrderList = aItemList.slice(0, 종목제한수);
}
else
{
for (var a = 0; a < nCount; a++)
{
var Add = true;
for (var b = 0; b < MKList.length; b++)
{
if (aItemList[a] == MKList[b].code)
{
Add = false;
}
}
if (Add == true && !IsStockInAccount(aItemList[a]))
{
OrderList.push(aItemList[a]);
if (OrderList.length >= 종목제한수)
{
break;
}
}
}
}
if (OrderList.length == 0)
{
Main.SetTimer(1, timer5 * 1000);
}
else
{
req = 0;
Main.ReqMarketData(OrderList[req]);
}
}
Search = -1;
}
else
{
if (nCount >= 1)
{
for (var a = 0; a < aItemList.Length; a++)
{
for (var b = 0; b < MKList.length; b++)
{
if (aItemList[a] == MKList[b].code)
{
Account1.SetBalance(aItemList[a], 0);
if (Account1.Balance.count > 0)
{
Account1.OrderSell(Account1.Balance.code,Account1.Balance.countc,0,1);
}
}
}
}
}
Main.SetTimer(1, timer5 * 1000);
Search = 1;
}
}
function Main_OnRcvMarketData(MarketData)
{
if (MarketData.code == OrderList[req])
{
MKList.push(MarketData);
if (!IsStockInAccount(MarketData.code))
{
Account1.OrderBuy(MarketData.code, 1, 0, 1);
Main.MessageList(MarketData.code + " 주식을 매수합니다.");
}
else
{
Main.MessageList(MarketData.code + " 주식은 이미 계좌에 있으므로 매수하지 않습니다.");
}
req = req + 1;
if (req < OrderList.length)
{
var aa = Main.ReqMarketData(OrderList[req]);
if (aa == -1)
{
Main.SetTimer(2, 15000);
}
}
else
{
Main.SetTimer(1, timer5 * 1000);
}
}
}
function IsStockInAccount(stockCode)
{
var numberOfBalances = Account1.GetTheNumberOfBalances();
for (var i = 0; i < numberOfBalances; i++)
{
Account1.SetBalance(i);
if (stockCode == Account1.Balance.code)
{
return true;
}
}
return false;
}
2025-04-03
418
글번호 189827