커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1587
글번호 230811
답변완료
질문드리겠습니다
지난 답변 감사드립니다
차트를 위아래로 분할 적용을 해봤는데요, 위아래로 2개로 했습니다
종목연동이 상단차트에만 적용이 되는데 하단 차트에도 같이 연동이 되게 하려면 어떻게 하면 될까요??
예로 종목검색창과 차트를 연동시켜놨는데
하단 차트 클릭하면 이미 연동이 돼있는걸로 나옵니다 (파란색 화살표)
그런데 클릭해도 상단만 바뀌고 하단은 반영이 안되네요
감사합니다
2025-03-06
359
글번호 188848
답변완료
수식
안녕하세요.
도움 주셔서 늘 감사합니다~
제가 요청 드리는 것은
1) 지난 10개월간 240이평선을 돌파 한 적이 없는 상태에서
2) 최근 100억원이 넘은 거래량을 동반해 240이평선을 처음 돌파 한 뒤
3) 돌파한지 20일 이내에 다시 240일 이평선 아래로 처음 내려온 종목 중
3) 첫번째 양봉 혹은 2번째 양봉. (240일 이평선 위에서 240일 이평선 아래로 내려오는 과정 중에는 양봉과 음봉이 섞일 수 있습니다)
을 찾는 종목검색식을 부탁 드립니다.
가능하시면 condition~ 을 사용해 부탁 드려요~
좋은 하루 보내세요.
감사합니다.
2025-03-06
334
글번호 188844
답변완료
시스템문의
1.아래 지표를 시스템으로 좀 수정 해주세요
#=================#=======================================#
Input : signal(5),굵기2(1),굵기3(1),굵기4(1);
#=================#=======================================#
Var : CC9(0),CC91(0);
#=================#
CC9 =data7(C);
#=================#
#=================#
CC91 = data4(C);
#=================#
#===================#
Var : MACDV(0) , MACDS(0),T(0);
var : HIV(0),HID(0),HIT(0),HIV1(0),HID1(0),HIT1(0),HI(0),HI1(0);
var : HPV(0),HPD(0),HPT(0),HPV1(0),HPD1(0),HPT1(0);
var : LIV(0),LID(0),LIT(0),LIV1(0),LID1(0),LIT1(0),LI(0),LI1(0);
var : LPV(0),LPD(0),LPT(0),LPV1(0),LPD1(0),LPT1(0);
var : TL1(0),TL2(0),TX1(0),TX2(0),TX3(0);
var : TL3(0),TL4(0),TL5(0),i1(0),i2(0);
MACDV = CC9;
MACDS = ema(MACDV,signal);
if (MACDV >= MACDV[1] and MACDV[1] >= MACDV[2]) Then
{
T = 1;
HIV = MACDV;
HID = sdate;
HIT = stime;
HI = Index;
HIV1 = HIV[1];
HID1 = HID[1];
HIT1 = HIT[1];
HPV = H;
HPD = sdate;
HPT = stime;
HI1 = HI[1];
HPV1 = HPV[1];
HPD1 = HPD[1];
HPT1 = HPT[1];
Condition1 = false;
}
if (MACDV <= MACDV[1] and MACDV[1] <= MACDV[2] ) Then
{
T = -1;
LIV = MACDV;
LID = sdate;
LIT = stime;
LI = Index;
LIV1 = LIV[1];
LID1 = LID[1];
LIT1 = LIT[1];
LPV = L;
LPD = sdate;
LPT = stime;
LI1 = LI[1];
LPV1 = LPV[1];
LPD1 = LPD[1];
LPT1 = LPT[1];
Condition2 = false;
}
if T == 1 Then
{
if MACDV > HIV Then
{
HIV = MACDV;
HID = sdate;
HIT = stime;
}
if H > HPV Then
{
HPV = H;
HPD = sdate;
HPT = stime;
}
if Condition1 == false and HPV1 > 0 and HPV > HPV1 and HIV < HIV1 and HI <= HI1+30 Then
{
TL1 = TL_New(HPD1,HPT1,HPV1,HPD,HPT,HPV);
TL2 = TL_New_Self(HID1,HIT1,HIV1,HID,HIT,HIV);
TL_SetColor(TL1,MAGENTA);
TL_SetColor(TL2,MAGENTA);
TL_SetSize(TL1,굵기2);
TL_SetSize(TL2,굵기2);
//tx1 = Text_New(HPD1,HPT1,HPV1,NumToStr(HPV1,2));
//tx2 = Text_New(HPD,HPT,HPV,NumToStr(HPV,2));
//tx3 = Text_New(HPD,HPT,(HPV1+HPV)/2,NumToStr((HPV1+HPV)/2,2));
Text_SetStyle(tx1,2,1);
Text_SetStyle(tx2,2,1);
//TL3 = TL_New(HPD1,HPT1,HPV1,sdate,stime,HPV1);
//TL4 = TL_New(HPD1,HPT1,HPV,HPD,HPT,HPV);
//TL5 = TL_New(HPD1,HPT1,(HPV1+HPV)/2,HPD,HPT,(HPV1+HPV)/2);
Condition1 = true;
}
if Condition1 == true then
{
if HPV > HPV1 and HIV < HIV1 then
{
TL_SetEnd(TL1,HPD,HPT,HPV);
TL_SetEnd(TL2,HID,HIT,HIV);
Text_SetLocation(tx2,HPD,HPT,HPV);
Text_SetString(tx2,NumToStr(HPV,2));
i1 = index;
}
Else
{
TL_Delete(TL1);
TL_Delete(TL2);
TL_Delete(TL3);
TL_Delete(TL4);
TL_Delete(TL5);
Text_Delete(tx1);
Text_Delete(tx2);
}
}
}
if T == -1 Then
{
if MACDV < LIV Then
{
LIV = MACDV;
LID = sdate;
LIT = stime;
}
if L < LPV Then
{
LPV = L;
LPD = sdate;
LPT = stime;
}
if Condition2 == false and LPV1 > 0 and LPV < LPV1 and LIV > LIV1 and LI <= LI1+30 Then
{
TL1 = TL_New(LPD1,LPT1,LPV1,LPD,LPT,LPV);
TL2 = TL_New_Self(LID1,LIT1,LIV1,LID,LIT,LIV);
TL_SetColor(TL1,WHITE);
TL_SetColor(TL2,WHITE);
TL_SetSize(TL1,굵기2);
TL_SetSize(TL2,굵기2);
//tx1 = Text_New(LPD1,LPT1,LPV1,NumToStr(LPV1,2));
//tx2 = Text_New(LPD,LPT,LPV,NumToStr(LPV,2));
//tx3 = Text_New(LPD,LPT,(LPV1+LPV)/2,NumToStr((LPV1+LPV)/2,2));
Text_SetStyle(tx1,2,1);
Text_SetStyle(tx2,2,1);
//TL3 = TL_New(LPD1,LPT1,LPV1,sdate,stime,LPV1);
//TL4 = TL_New(LPD1,LPT1,LPV,LPD,LPT,LPV);
//TL5 = TL_New(LPD1,LPT1,(LPV1+LPV)/2,LPD,LPT,(LPV1+LPV)/2);
Condition2 = true;
}
if Condition2 == true then
{
if LPV < LPV1 and LIV > LIV1 then
{
TL_SetEnd(TL1,LPD,LPT,LPV);
TL_SetEnd(TL2,LID,LIT,LIV);
Text_SetLocation(tx2,LPD,LPT,LPV);
Text_SetString(tx2,NumToStr(LPV,2));
i2 = index;
}
Else
{
TL_Delete(TL1);
TL_Delete(TL2);
TL_Delete(TL3);
TL_Delete(TL4);
TL_Delete(TL5);
Text_Delete(tx1);
Text_Delete(tx2);
}
}
}
if index > i1 and index <= i1+3 Then
{
TL_SetEnd(tl3,sdate,stime,TL_GetValue(tl3,sdate,stime));
TL_SetEnd(tl4,sdate,stime,TL_GetValue(tl4,sdate,stime));
TL_SetEnd(tl5,sdate,stime,TL_GetValue(tl5,sdate,stime));
}
if index > i2 and index <= i2+3 Then
{
TL_SetEnd(tl3,sdate,stime,TL_GetValue(tl3,sdate,stime));
TL_SetEnd(tl4,sdate,stime,TL_GetValue(tl4,sdate,stime));
TL_SetEnd(tl5,sdate,stime,TL_GetValue(tl5,sdate,stime));
}
#=================#
Var : MACDV2(0) , MACDS2(0),T2(0);
var : HIV2(0),HID2(0),HIT2(0),HIV3(0),HID3(0),HIT3(0),HI2(0),HI3(0);
var : HPV2(0),HPD2(0),HPT2(0),HPV3(0),HPD3(0),HPT3(0);
var : LIV2(0),LID2(0),LIT2(0),LIV3(0),LID3(0),LIT3(0),LI2(0),LI3(0);
var : LPV2(0),LPD2(0),LPT2(0),LPV3(0),LPD3(0),LPT3(0);
var : TL26(0),TL27(0),TX26(0),TX27(0),TX28(0);
var : TL28(0),TL29(0),TL30(0),TL31(0),i26(0),i27(0);
MACDV2 = CC91;
MACDS2 = ema(MACDV2,signal);
if crossup(MACDV2,MACDS2) Then
{
T2 = 1;
HIV2 = MACDV2;
HID2 = sdate;
HIT2 = stime;
HI2 = Index;
HIV3 = HIV2[1];
HID3 = HID2[1];
HIT3 = HIT2[1];
HPV2 = H;
HPD2 = sdate;
HPT2 = stime;
HI3 = HI2[1];
HPV3 = HPV2[1];
HPD3= HPD2[1];
HPT3 = HPT2[1];
Condition1 = false;
}
if CrossDown(MACDV2,MACDS2) Then
{
T2 = -1;
LIV2 = MACDV2;
LID2 = sdate;
LIT2 = stime;
LI2 = Index;
LIV3 = LIV2[1];
LID3 = LID2[1];
LIT3 = LIT2[1];
LPV2 = L;
LPD2 = sdate;
LPT2 = stime;
LI3 = LI2[1];
LPV3 = LPV2[1];
LPD3 = LPD2[1];
LPT3 = LPT2[1];
Condition2 = false;
}
if T2 == 1 Then
{
if MACDV2 > HIV2 Then
{
HIV2 = MACDV2;
HID2 = sdate;
HIT2 = stime;
}
if H > HPV2 Then
{
HPV2 = H;
HPD2 = sdate;
HPT2 = stime;
}
if Condition1 == false and HPV3 > 0 and HPV2 > HPV3 and HIV2 < HIV3 and HI2 <= HI3+30 Then
{
TL26 = TL_New(HPD3,HPT3,HPV3,HPD2,HPT2,HPV2);
TL27 = TL_New_Self(HID3,HIT3,HIV3,HID2,HIT2,HIV2);
TL_SetColor(TL26,MAGENTA);
TL_SetColor(TL27,MAGENTA);
TL_SetSize(TL26,굵기3);
TL_SetSize(TL27,굵기3);
//tx1 = Text_New(HPD1,HPT1,HPV1,NumToStr(HPV1,2));
//tx2 = Text_New(HPD,HPT,HPV,NumToStr(HPV,2));
//tx3 = Text_New(HPD,HPT,(HPV1+HPV)/2,NumToStr((HPV1+HPV)/2,2));
Text_SetStyle(tx26,2,1);
Text_SetStyle(tx27,2,1);
//TL3 = TL_New(HPD1,HPT1,HPV1,sdate,stime,HPV1);
//TL4 = TL_New(HPD1,HPT1,HPV,HPD,HPT,HPV);
//TL5 = TL_New(HPD1,HPT1,(HPV1+HPV)/2,HPD,HPT,(HPV1+HPV)/2);
Condition1 = true;
}
if Condition1 == true then
{
if HPV2 > HPV3 and HIV2 < HIV3 then
{
TL_SetEnd(TL26,HPD2,HPT2,HPV2);
TL_SetEnd(TL27,HID2,HIT2,HIV2);
Text_SetLocation(tx27,HPD2,HPT2,HPV2);
Text_SetString(tx27,NumToStr(HPV2,2));
i26 = index;
}
Else
{
TL_Delete(TL26);
TL_Delete(TL27);
TL_Delete(TL28);
TL_Delete(TL29);
TL_Delete(TL30);
Text_Delete(tx26);
Text_Delete(tx27);
}
}
}
if T2 == -1 Then
{
if MACDV2 < LIV2 Then
{
LIV2 = MACDV2;
LID2 = sdate;
LIT2 = stime;
}
if L < LPV2 Then
{
LPV2 = L;
LPD2 = sdate;
LPT2 = stime;
}
if Condition2 == false and LPV3 > 0 and LPV2 < LPV3 and LIV2 > LIV3 and LI2 <= LI3+30 Then
{
TL26 = TL_New(LPD3,LPT3,LPV3,LPD2,LPT2,LPV2);
TL27 = TL_New_Self(LID3,LIT3,LIV3,LID2,LIT2,LIV2);
TL_SetColor(TL26,WHITE);
TL_SetColor(TL27,WHITE);
TL_SetSize(TL26,굵기3);
TL_SetSize(TL27,굵기3);
//tx1 = Text_New(LPD1,LPT1,LPV1,NumToStr(LPV1,2));
//tx2 = Text_New(LPD,LPT,LPV,NumToStr(LPV,2));
//tx3 = Text_New(LPD,LPT,(LPV1+LPV)/2,NumToStr((LPV1+LPV)/2,2));
Text_SetStyle(tx26,2,1);
Text_SetStyle(tx27,2,1);
//TL3 = TL_New(LPD1,LPT1,LPV1,sdate,stime,LPV1);
//TL4 = TL_New(LPD1,LPT1,LPV,LPD,LPT,LPV);
//TL5 = TL_New(LPD1,LPT1,(LPV1+LPV)/2,LPD,LPT,(LPV1+LPV)/2);
Condition2 = true;
}
if Condition2 == true then
{
if LPV2 < LPV3 and LIV2 > LIV3 then
{
TL_SetEnd(TL26,LPD2,LPT2,LPV2);
TL_SetEnd(TL27,LID2,LIT2,LIV2);
Text_SetLocation(tx27,LPD2,LPT2,LPV2);
Text_SetString(tx27,NumToStr(LPV2,2));
i27 = index;
}
Else
{
TL_Delete(TL26);
TL_Delete(TL27);
TL_Delete(TL28);
TL_Delete(TL29);
TL_Delete(TL30);
Text_Delete(tx26);
Text_Delete(tx27);
}
}
}
if index > i26 and index <= i26+3 Then
{
TL_SetEnd(tl29,sdate,stime,TL_GetValue(tl29,sdate,stime));
TL_SetEnd(tl30,sdate,stime,TL_GetValue(tl30,sdate,stime));
TL_SetEnd(tl31,sdate,stime,TL_GetValue(tl31,sdate,stime));
}
if index > i27 and index <= i27+3 Then
{
TL_SetEnd(tl29,sdate,stime,TL_GetValue(tl29,sdate,stime));
TL_SetEnd(tl30,sdate,stime,TL_GetValue(tl30,sdate,stime));
TL_SetEnd(tl31,sdate,stime,TL_GetValue(tl31,sdate,stime));
}
#===================#
plot1(ma(C, DnLevel),"몸통", Black); //음봉이면 파란색
2.그럼 수고하세요
2025-03-06
354
글번호 188843
답변완료
수식문의입니다
1. 지표수식
LL = Lowest(L,120);
가. 위 지표처럼 120일간의 최저가캔들에서 캔들의 고가와 Min(C,O)의 중심선을 표시하는
가격라인수식(기준가로 설정)
나. 위 기준가 라인은 보통 계단식으로 유지되다가 변경되는데 동일한 기준가로 2회이상
유지되는 경우 <저장기준가>로 저장하고, 현재 기준가이전에 수평가격으로 형성된
저장기준가라인의 마지막봉에 1, 그이전 수평기준가라인 말단봉에 2,...과거봉으로
추적하면서 번호를 4회까지만 표시되게하는 수식. 현재 기준가와 1번,2번,3번,4번간
서로 비교할 수 있게 별도의 저장값 수식도 표시요망. 여기서 주가가 계속 최저가가
갱신되는 경우는 1회이하의 동일가격이므로 무시되어 번호 카운팅하면 안됨.
따라서 가격비교를 위한 저장값을 가지면 안되고 2회이상 유지된 라인 가격만 저장.
단. 단 여기서 1봉전까지는 최저가가 하락하다가 당일 0봉전캔들에서는 더이상 전일
최저가를 하락 갱신하지 않는 경우에는 위 기준가는 변동되지않고 1봉전기준가와
0봉전기준가는 동일하므로 연속 2회이상 동일 기준가로 변동이 없으므로 0번이 표시
되고 <저장기준가>로 저장되어 종목검색시의 비교 저장기준가가 된다. 연속2이상 동일
한 기준가인 라인을 하나의 라인으로 보고 번호를 저장하되 현재의 캔들이 포함된
동일한 기준가인 경우는 0번에 저장하고, 현재의 캔들이 포함되지 않은 현재 이전의
최근라인부터는 1번부터 부여해 간다는 의미이고, 돌파검색의 기준은 우선 0번부터
시작되고 0번값이 없으면 1번값이 기준이 된다.
2. 종목검색수식
위 <1-나>에 저장된 가격을 비교하여 돌파하는 종목을 검색하고자 하는 수식.
현재의 기준가은 1번 저장기준가보다 같거나 낮고, 시가종가로 1번 저장기준가을 돌파할
때의 종목검색수식. 단. 0번 저장기준가가 발생하는 경우는 이 가격돌파시 검색되어야
함. 부연하면 시가종가상으로 단순히 1봉전 기준가을 돌파할때의 검색이 아니고 현재의
기준가이전에 형성된 가장 최근의 2회연속 동일한 가격으로 형성된 저장기준가(1번저장
값 똔는 0번 저장가가 우선임)를 돌파할때의 종목 검색수식임
2025-03-06
363
글번호 188842
답변완료
시스템이 원하는 신호가 안나옵니다.(2)
안녕하세요?
일전에 친절한 안내 잘 받았습니다(91686번글). 바쁘실텐데 항상 친절하고 성심 성의껏 응대 해주셔서 항상 감사합니다.
말씀하신대로 data1을 구별하여 시스템을 적용시켜 보았는데, 처음에는 청산식이 없는 것 같아, 신호가 안나오는 듯하여 청산식으로 ATR을 사용하여 만들어 보았더니 시스템이 작동하는 듯하였습니다.
그런데 제가 원하는 시스템은
data2의 macd 오실래이터가 양수일때,data1의 macd 오실래이터가 양수인 경우 매수신호가,
macd 오실래이터가 음수일때,data1의 macd 오실래이터가 음수인 경우 매도신호가,
나오는 것인데,
data2의 macd 오실래이터가 양수일때,data1의 macd 오실래이터가 음수인 경우에도 매수신호가,계속 나옵니다.혹은 그 반대의 경우에도 다른 신호가 계속 나옵니다.
코딩이 뭐가 잘 못 된것인지 다시 한번 봐 주시면 감사하겠습니다,
미리 감사 인사 올립니다.
input : shortPeriod(12),longPeriod(26),Period(9);
input : P1(12),P2(26),P3(9);
Input : H1(10),L1(10);
Var : macdv1(0,Data1),macds1(0,Data1),macdo1(0,Data1);
var : macdv2(0,data2),macds2(0,data2),macdo2(0,Data2);
var : mav(0,Data1);
macdv1 = data1(MACD(shortPeriod, longPeriod));
macds1 = data1(ema(macdv1,Period));
macdo1 = macdv1-macds1;
macdv2 = data2(MACD(P1,P2));
macds2 = data2(ema(macdv2,P3));
macdo2 = macdv2-macds2;
mav = data1(ema(C,26));
if marketposition == 0 and
macdo1 > 0 and
macdo2 > 0 and
(C >= mav+data1(PriceScale*H1)) Then
Buy("L");
if marketposition == 0 and
macdo1 < 0 and
macdo2 < 0 and
(C <= mav-data1(PriceScale*L1)) Then
Sell("S");
### ATR Trailing LX(매수청산)###
Inputs: ATRs_L(3);
Variables: PosHigh(0,Data1), ATRVal_L(0,Data1);
ATRVal_L = data1(ATR(10) * ATRs_L);
If BarsSinceEntry() == 0 Then
PosHigh = High;
If MarketPosition() == 1 Then Begin
If High > PosHigh Then
PosHigh = High;
ExitLong ("ATRS", AtStop, PosHigh - ATRVal_L);
End
else
ExitLong("ATR ebs", AtStop, High - ATRVal_L);
### ATR Trailing SX(매도청산)###
Inputs: ATRs_S(3);
Variables: PosLow(0,Data1), ATRVal_S(0,Data1);
ATRVal_S = data1(ATR(10) * ATRs_S);
If BarsSinceEntry() == 0 Then
PosLow = Low;
If MarketPosition() == -1 Then Begin
If Low < PosLow Then
PosLow = Low;
ExitShort ("ATRL", AtStop, PosLow + ATRVal_S);
End
else
ExitShort ("ATR ebL", AtStop, Low + ATRVal_S);
2025-03-06
388
글번호 188841
답변완료
수식요청
다=Lowest(L(1),기간);
바=Highest(H(1),기간);
스=Valuewhen(1,BarsSince(L<다(1))==(기간-간격),바)
(기간:15, 간격:3)
위 수식으로 그어지는 다바스 상단선을 상향돌파하는 종목을 검색코자 합니다.
예스 수식이 가능할까요?
2025-03-05
423
글번호 188840
길게가자 님에 의해서 삭제되었습니다.
2025-03-05
0
글번호 188839
답변완료
검색식 문의 드립니다.
안녕하세요.
검색식 문의 드립니다.
A:볼린저밴드 하한선(20,2)값이 볼린저밴드 하한선(50,2)값보다 작을때 조건
B:볼린저밴드 상한선(20,2)값이 볼린저밴드 상한선(50,2)값보다 클때 조건
1)A or B
2)A and B
부탁드립니다.
2025-03-05
344
글번호 188838
답변완료
종목검색식 부탁드림니다.
항상 노고에 감사드림니다.
아래의 수식을 종목검색식으로 부탁드림니다.
A=ma(c,5,단순);
B=ma(c,20,단순);
B1=ma(c,120,단순);
CrossUp(A,B) &&
A>A(1) &&
C>O &&
MACD(12,26)>0 &&
B1<C
2025-03-05
354
글번호 188837