커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1649
글번호 230811
답변완료
수정부탁드립니다
#,안녕하세요
아래식에서 TL라인1~10번까지를 당일Y축까지 표시할수 있는 방법을 찾고 있습니다,
Y축까지 오른쪽 수평그리기하면 좋겠는데 가능 할지 모르겠습니다,다른방법이
있으면 도움 부탁드립니다.
input : af(0.02), maxAF(0.2),텍스트출력(1),크기(0);
var : T(0),HH(0),LL(0),HD(0),HT(0),LD(0),LT(0);
var : HH1(0),LL1(0),HD1(0),HT1(0),LD1(0),LT1(0);
var : TL1(0),TL2(0),TL3(0),TL4(0),TL5(0);
var : TL6(0),tl7(0),TL8(0),TL9(0),TL10(0);
var : tx1(0),tx2(0),tx11(0),tx22(0);
var : x1(0),x2(0),x3(0),x4(0),x5(0);
var : x6(0),x7(0),x8(0),x9(0),x10(0);
var1 = CSar(af,maxAF);
if crossup(c,var1) Then
{
T = 1;
HH = H;
HD = sdate;
HT = stime;
HH1 = HH[1];
HD1 = HD[1];
HT1 = HT[1];
if LL > 0 Then
{
if 텍스트출력 == 1 then
{
Tx11 = Text_New(HD1,HT1,HH1,NumToStr((HH1-LL1),2)+NewLine+NumToStr(HH1,2));
Text_SetStyle(tx11,2,1);
Text_SetColor(tx11,BLUE);
Text_SetSize(tx11,크기);
Text_Delete(tx1);
Tx1 = Text_New(HD,HT,HH,NumToStr((HH-LL[1]),2)+NewLine+NumToStr(HH,2));
Text_SetStyle(tx1,2,1);
Text_SetColor(tx1,BLUE);
Text_SetSize(tx1,크기);
}
}
}
if CrossDown(c,var1) Then
{
T = -1;
LL = L;
LD = sdate;
LT = stime;
LL1 = LL[1];
LD1 = LD[1];
LT1 = LT[1];
if HH > 0 Then
{
if 텍스트출력 == 1 then
{
Tx22 = Text_New(LD1,LT1,LL1,NumToStr((HH1-LL1),2)+NewLine+NumToStr(LL1,2));
Text_SetStyle(tx22,2,0);
Text_SetColor(tx22,RED);
Text_Delete(tx2);
Text_SetSize(tx22,크기);
Tx2 = Text_New(LD,LT,LL,NumToStr((HH[1]-LL),2)+NewLine+NumToStr(LL,2));
Text_SetStyle(tx2,2,0);
Text_SetColor(tx2,RED);
Text_SetSize(tx2,크기);
}
}
}
if T == 1 then
{
if H > HH Then
{
HH = H;
HD = sdate;
HT = stime;
if 텍스트출력 == 1 then
{
Text_Delete(tx1);
Tx1 = Text_New(HD,HT,HH,NumToStr((HH-LL[1]),2)+NewLine+NumToStr(HH,2));
Text_SetStyle(tx1,2,1);
Text_SetColor(tx1,BLUE);
Text_SetSize(tx1,크기);
}
}
}
if T == -1 then
{
if L < LL Then
{
LL = L;
LD = sdate;
LT = stime;
if 텍스트출력 == 1 then
{
Text_Delete(tx2);
Tx2 = Text_New(LD,LT,LL,NumToStr((HH[1]-LL),2)+NewLine+NumToStr(LL,2));
Text_SetStyle(tx2,2,0);
Text_SetColor(tx2,RED);
Text_SetSize(tx2,크기);
}
}
}
if nextbarsdate != sdate Then
{
if T == 1 Then
{
TL_Delete(TL1);
TL_Delete(TL2);
TL_Delete(TL3);
TL_Delete(TL4);
TL_Delete(TL5);
#TL1 = TL_New(LD,LT,HH,sDate,sTime,HH);
TL2 = TL_New(LD,LT,HH1+1.0,sDate,sTime,HH1+1.0);
TL3 = TL_New(LD,LT,HH1+1.618,sDate,sTime,HH1+1.618);
TL4 = TL_New(LD,LT,HH1-1.0,sDate,sTime,HH1-1.0);
TL5 = TL_New(LD,LT,HH1-1.618,sDate,sTime,HH1-1.618);
TL_SetColor(TL1,BLUE);
TL_SetColor(TL2,BLUE);
TL_SetColor(TL3,BLUE);
TL_SetColor(TL4,BLUE);
TL_SetColor(TL5,BLUE);
TL_Delete(TL6);
TL_Delete(TL7);
TL_Delete(TL8);
TL_Delete(TL9);
TL_Delete(TL10);
#TL6 = TL_New(LD,LT,LL,sDate,sTime,LL);
TL7 = TL_New(LD,LT,LL+1.0,sDate,sTime,LL+1.0);
TL8 = TL_New(LD,LT,LL+1.618,sDate,sTime,LL+1.618);
TL9 = TL_New(LD,LT,LL-1.0,sDate,sTime,LL-1.0);
TL10 = TL_New(LD,LT,LL-1.618,sDate,sTime,LL-1.618);
TL_SetColor(TL6,RED);
TL_SetColor(TL7,RED);
TL_SetColor(TL8,RED);
TL_SetColor(TL9,RED);
TL_SetColor(TL10,RED);
Text_Delete(x1);
Text_Delete(x2);
Text_Delete(x3);
Text_Delete(x4);
Text_Delete(x5);
#x1 = Text_New(sDate,sTime,HH,NumToStr(HH,2));
x2 = Text_New(sDate,sTime,HH1+1.0,NumToStr(HH1+1.0,2));
x3 = Text_New(sDate,sTime,HH1+1.618,NumToStr(HH1+1.618,2));
x4 = Text_New(sDate,sTime,HH1-1.0,NumToStr(HH1-1.0,2));
x5 = Text_New(sDate,sTime,HH1-1.618,NumToStr(HH1-1.618,2));
Text_SetColor(x1,BLUE);
Text_SetColor(x2,BLUE);
Text_SetColor(x3,BLUE);
Text_SetColor(x4,BLUE);
Text_SetColor(x5,BLUE);
Text_SetStyle(x1,0,2);
Text_SetStyle(x2,0,2);
Text_SetStyle(x3,0,2);
Text_SetStyle(x4,0,2);
Text_SetStyle(x5,0,2);
Text_Delete(x6);
Text_Delete(x7);
Text_Delete(x8);
Text_Delete(x9);
Text_Delete(x10);
#x6 = Text_New(sDate,sTime,LL,NumToStr(LL,2));
x7 = Text_New(sDate,sTime,LL+1.0,NumToStr(LL+1.0,2));
x8 = Text_New(sDate,sTime,LL+1.618,NumToStr(LL+1.618,2));
x9 = Text_New(sDate,sTime,LL-1.0,NumToStr(LL-1.0,2));
x10 = Text_New(sDate,sTime,LL-1.618,NumToStr(LL-1.618,2));
Text_SetColor(x6,RED);
Text_SetColor(x7,RED);
Text_SetColor(x8,RED);
Text_SetColor(x9,RED);
Text_SetColor(x10,RED);
Text_SetStyle(x6,0,2);
Text_SetStyle(x7,0,2);
Text_SetStyle(x8,0,2);
Text_SetStyle(x9,0,2);
Text_SetStyle(x10,0,2);
}
Else
{
TL_Delete(TL1);
TL_Delete(TL2);
TL_Delete(TL3);
TL_Delete(TL4);
TL_Delete(TL5);
#TL1 = TL_New(HD,HT,HH,sDate,sTime,HH);
TL2 = TL_New(HD,HT,HH+1.0,sDate,sTime,HH+1.0);
TL3 = TL_New(HD,HT,HH+1.618,sDate,sTime,HH+1.618);
TL4 = TL_New(HD,HT,HH-1.0,sDate,sTime,HH-1.0);
TL5 = TL_New(HD,HT,HH-1.618,sDate,sTime,HH-1.618);
TL_SetColor(TL1,BLUE);
TL_SetColor(TL2,BLUE);
TL_SetColor(TL3,BLUE);
TL_SetColor(TL4,BLUE);
TL_SetColor(TL5,BLUE);
TL_Delete(TL6);
TL_Delete(TL7);
TL_Delete(TL8);
TL_Delete(TL9);
TL_Delete(TL10);
#TL6 = TL_New(HD,HT,LL1,sDate,sTime,LL1);
TL7 = TL_New(HD,HT,LL1+1.0,sDate,sTime,LL1+1.0);
TL8 = TL_New(HD,HT,LL1+1.618,sDate,sTime,LL1+1.618);
TL9 = TL_New(HD,HT,LL1-1.0,sDate,sTime,LL1-1.0);
TL10 = TL_New(HD,HT,LL1-1.618,sDate,sTime,LL1-1.618);
TL_SetColor(TL6,RED);
TL_SetColor(TL7,RED);
TL_SetColor(TL8,RED);
TL_SetColor(TL9,RED);
TL_SetColor(TL10,RED);
Text_Delete(x1);
Text_Delete(x2);
Text_Delete(x3);
Text_Delete(x4);
Text_Delete(x5);
#x1 = Text_New(sDate,sTime,HH,NumToStr(HH,2));
x2 = Text_New(sDate,sTime,HH+1.0,NumToStr(HH+1.0,2));
x3 = Text_New(sDate,sTime,HH+1.618,NumToStr(HH+1.618,2));
x4 = Text_New(sDate,sTime,HH-1.0,NumToStr(HH-1.0,2));
x5 = Text_New(sDate,sTime,HH-1.618,NumToStr(HH-1.618,2));
Text_SetColor(x1,BLUE);
Text_SetColor(x2,BLUE);
Text_SetColor(x3,BLUE);
Text_SetColor(x4,BLUE);
Text_SetColor(x5,BLUE);
Text_SetStyle(x1,0,2);
Text_SetStyle(x2,0,2);
Text_SetStyle(x3,0,2);
Text_SetStyle(x4,0,2);
Text_SetStyle(x5,0,2);
Text_Delete(x6);
Text_Delete(x7);
Text_Delete(x8);
Text_Delete(x9);
Text_Delete(x10);
#x6 = Text_New(sDate,sTime,LL1,NumToStr(LL1,2));
x7 = Text_New(sDate,sTime,LL1+1.0,NumToStr(LL1+1.0,2));
x8 = Text_New(sDate,sTime,LL1+1.618,NumToStr(LL1+1.618,2));
x9 = Text_New(sDate,sTime,LL1-1.0,NumToStr(LL1-1.0,2));
x10 = Text_New(sDate,sTime,LL1-1.618,NumToStr(LL1-1.618,2));
Text_SetColor(x6,RED);
Text_SetColor(x7,RED);
Text_SetColor(x8,RED);
Text_SetColor(x9,RED);
Text_SetColor(x10,RED);
Text_SetStyle(x6,0,2);
Text_SetStyle(x7,0,2);
Text_SetStyle(x8,0,2);
Text_SetStyle(x9,0,2);
Text_SetStyle(x10,0,2);
}
}
고맙습니다.
2021-06-29
1716
글번호 150392
답변완료
변경 부탁드립니다.
안녕하세요.....글번호72788 에서 포트56번 시가갭라인을 변경부탁드립니다.
9시장시작해서 첫봉을제외한 2번봉에서시작하여
장종료까지 고점과 저점의 중심값라인 부탁드립니다.
plot 56 중심라인
수고하세요...꾸벅
2021-06-29
1514
글번호 150391
답변완료
수식 부탁 드립니다.
관리자님,
수식 부탁 드립니다.
1) 1봉전 거래량을 상향시 즉시 매수
2) 음봉 발생시 즉시 매도
부탁드립니다.
2021-06-29
1347
글번호 150390
답변완료
문의
1. 해석 부탁하고요
stdv = std(C,P);
2. x는 포인트인가요?
stdv*x
***************************************************************************
안녕하세요
예스스탁입니다.
input : P(20),X(2);
var : stdv(0);
stdv = std(C,P);
if MarketPosition == 1 Then
ExitLong("bx",AtStop,EntryPrice-stdv*x);
if MarketPosition == -1 Then
ExitShort("sx",AtStop,EntryPrice+stdv*x);
즐거운 하루되세요
> 목마와숙녀 님이 쓴 글입니다.
> 제목 : 문의
> 표준편차를 이용한
손절 수식 예를 부탁드립니다.
2021-06-29
1265
글번호 150389
답변완료
일요일 자정에 매수진입, 토요일 정오에 청산하는 코딩식 좀 부탁드리겠습니다.(코인)
일요일 자정에 매수진입, 토요일 정오에 청산하는 코딩식 좀 부탁드리겠습니다.(코인)
2021-06-29
1242
글번호 150386
답변완료
추가 요청3
안녕하세요?
문의에 매번 답변 주심에 항상 감사드립니다.
아래 로직에서 진입후 만약 수익이 났다가 익절 되지 않고
다시 되돌림이 와서 진입가에 도달하면 본절하는 조건을 추가할수 있는지요?
---------------
input : P1(5),P2(20);
input : sto1(10),sto2(5),sto3(5);
var : stok(0),stod(0);
var : mav1(0),mav2(0),T(0);
stok = stochasticsK(sto1,sto2);
stod = stochasticsD(sto1,sto2,sto3);
mav1 = ma(C,P1);
mav2 = ma(C,P2);
if CrossUp(mav1,mav2) Then
T = 1;
if CrossDown(mav1,mav2) Then
T = -1;
if T == 1 and CrossUp(stok,stod) Then
{
T = 2;
Buy("b");
}
if T == -1 and CrossDown(stok,stod) Then
{
T = -2;
Sell("s");
}
SetStopProfittarget(1.3,PointStop);
SetStopLoss(0.8,PointStop);
var : month(0),nday(0),week(0);
month = int(date/100)-int(date/10000)*100;
nday = date - int(date/100)*100;
Week = DayOfWeek(date);
if (month%3 == 0 and nday >= 8 and nday <= 14 and week == 4) then
SetStopEndofday(151500);
Else
SetStopEndofday(153000);
2021-06-29
1268
글번호 150380
답변완료
부탁 드립니다~~^^
1번 봉에 종가 보다
2번 봉에 시가가 낮아야 됨 ===> 즉, 갭 하락이 발생 되어야 됩니다( 양, 음 관계 없이)
그 후, 음봉이 더 나와도 되고, 아니면 곧바로 양봉이 나오는 날
종목을 찾고 싶습니다.
" 갭 하락 후, 양봉
1번 2번 갭 하락 후 => 양봉이 나온 날 (종목 검출)
부탁 드립니다.
2021-06-29
1371
글번호 150372
답변완료
수식작성 문의드립니다.
첫번째 조건을 만족한 상태이후 두번째 조건을 만족할때 주문신호가 나가는
수식을 작성하고자 합니다.
가령, VR 의 매도신호의 경우 아래 조건을 만족한 이후
5이평선이 20이평선을 하회하는 경우에 매도를 진행하는 수식을 작성하려면 어떻게
해야할까요 ?
If CrossDown(value, 300) Then
{
Sell();
}
수고에 감사드립니다~~
2021-06-29
1474
글번호 150371
답변완료
문의드립니다.
안녕하세요, 노고에 항상 감사드립니다.
현재 사용중인 일봉 거래 시스템에 다음 분봉 상 고점 돌파 로직을 추가 적용해보고자
다음 내용을 수식화 했습니다.
1.종가(day2)가 전일(day1) 종가 대비 10프로 이상 상승하고 10시이전 고점을 당일(day2) 2시30분 이후에 돌파
2. 익일(day3) 종가가 10%이상 상승
3. 익익일(day4) 주가가 직전일(day3) 종가 대비 5% 하락 시 매수
If C >= O*1.1 then
{
high1 = true;
if timehigh(90000,95959) < timehigh(143000, 153000) then
{
high2 = true;
}
else
{
High2 = false;
}
High_index = index;
}
If high1 == true and high_index >0 and index == high_index + 1 and h >= C[1] *1.1 then
{
if high2 == true then
S_pick = true;
Else
S_pick = false;
}
Else
{
High1 = false;
High2 = false;
High_index = 0;
S_pick = false;
}
If high1 == true and S_pick == true and index == high_index+2 then
Buy("b1", atlimit, c[1]*0.95);
문의 드리고자 하는 내용은 다음과 같습니다.
1. timehigh를 일봉거래 시에 사용할 수 있나요?
2. timehigh를 당일 장 중이 아닌 지나간 일봉에서도 사용가능한가요?(과거 데이터 시뮬레이션용)
3. 불가능하다면 어떻게 활용할 수 있을까요?
(예,분봉 검색식 활용하여 수기로 걸러냄, 분봉 매수/매도식 작성하여 타주기참조, 전체 시스템을 분봉용으로 재작성 등)
4. 분봉 거래만 가능하다면 분봉 수식으로 변환도 부탁드립니다.
감사합니다. 오늘도 즐거운 하루 보내세요.
2021-06-29
1736
글번호 150370