커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4701
글번호 230811
답변완료
종목검색
안녕하세요,
주식 종목검색식에서,
장시작 09:00시초가를 만드는 최고매수가와 최저매도가를
만드는 수식이 가능할까요? 시간두 포함해서요.
새해 돈많이 버세요.
2015-12-31
147
글번호 93948
답변완료
문의드립니다.
수고 많으십니다.
1)아래 수식에서 당일 최대손실이 -3 point 되면 즉시 당일매매 중단되게 해주세요.
2)그리고 당일 거래 횟수를 5회로 해주세요.
모두 변수로 해주세요.
------------------------------------------------------------------
INPUT : LENGTH(100), PRO(0.1), LOSS(5),T(144900),TICK(20);
VAR : TCHAN(0), BCHAN(0);
var : bs1(0),ss1(0);
var : bs2(0),ss2(0);
var : bs3(0),ss3(0);
var : bl(0),bh(0), sh(0), sl(0);
TCHAN = HIGHEST(HIGH, LENGTH)[1];
BCHAN = LOWEST(LOW, LENGTH)[1];
// TCHAN 보다 크면 매수 1단계
if TCHAN[1] < H[1] then {bs1 = 1;}
if BCHAN[1] > L[1] then {ss1 = 1;}
// 만약 매수 1단계 진행중 BCHAN의 저가를 깨면 매수단계 초기화
if bs1 == 1 and BCHAN > L then {bs1=0; }
if ss1 == 1 and TCHAN < H then {ss1=0; }
//진입
if bs1 == 1 then {buy("매수",atlimit,TCHAN-PriceScale*TICK); }
if ss1 == 1 then {sell("매도",atlimit,BCHAN+PriceScale*TICK); }
SetStopProfittarget(PRO,PointStop);
SetStopLoss(LOSS,PointStop);
-----------------------------------------------------------------------
2016-01-01
154
글번호 93947
답변완료
45741번 수식 수정부탁드립니다. 감사합니다
지표,시스템 둘 다 수정 부탁드립니다
감사합니다
2015-12-30
182
글번호 93946
답변완료
수식작성시 재무관련 정보이용은 가능한가요?
시총과 자본총액을 비교해서
가령 시총 > 자본총액, 시총 < 자본총액
이런 수식을 넣어서 종목을 검색할수있을까요?
2015-12-30
143
글번호 93944
답변완료
수정 부탁드립니다.
한해 동안 수고 많으셨습니다. 올 한해 동안 좋은 일만 기억하시고, 새해에는 건강과 행복이 가득하시길 바랍니다.
매수호가 총수량을 매수호가 총건수로 나누는 식을 만들어 보았으나 지표가 나타나지를 않습니다. 검토 부탁드립니다.
감사합니다.
=====================================================================
Var1 = Data1(c); // 선물 매수호가 총건수
Var2 = Bids; // 선물 매수호가 총수량
Var3 = Var2 / Var1; // 매수 1건당수량
Var4 = Var3[1] / Var3[0]; // 이전봉의 값과 지금봉의 값과의 비율
Plot1(Var3,"매수1건당수량",RED);
Plot2(Var4,"매수전봉값과의비율",RED);
PlotBaseLine1(0,"0");
PlotBaseLine2(1,"1");
2015-12-30
144
글번호 93943
답변완료
주문에 대해 문의드립니다.
항상 친절한 답변에 감사드립니다. 다시 한번 새해 건승을 기원드립니다.
1. 미체결된 매수 1계약 주문이 증권사에 나가 있는 상태에서 매도 시그널을 만나 매도 1계약 주문을 전송하면 주문이 제로인 상태가 되나요? 아니면 매수 1계약 주문과 매도 1계약 주문을 동시에 갖게 되나요? 아니면 시스템이 오류가 나 그 이후부터 시스템이 멈춰지나요?
2. 위와 같이 매수 1계약 주문이 나가 있는 상태에서 매도 2계약 주문을 전송하면 매도 1계약 주문만 갖게 되나요?
3. Buy, Sell 함수는 기존에 있던 반대 포지션을 청산하고 새롭게 주문을 내는 것으로 알고 있습니다. 그러면 기존에 매수 포지션 2계약이 있는 상태에서 매도 시그널이 나서 sell(4계약)이 실행되면 매도 4계약을 갖게 됩니까 상쇄되 매도 2계약만 갖게 됩니까?
2015-12-30
141
글번호 93935
답변완료
문의드립니다
아래수식을 시스템식으로 변경 부탁드립니다
사진첨부합니다
5이동편균을 추가하여 이동편균이 추세선을 돌파시매수 또는매도 부탁드립니다
손절0.50과 수익청산0.95도 부탁드립니다
var11 = ma(c,Period1);
var22 = TL1;
var33 = TL2;
if CrossUp(var11,var33) Then
{
Buy();
}
if CrossDown(var11,var22) Then
{
Sell();
}
위처럼 식을 해보니 신호가 안나오고있습니다
사진참고 부탁드립니다
미리감사드립니다
Input:chRate(0.5); //전환율 또는 변동률
Var:j(0),upTr(100),dnTr(-100),upRate(0),dnRate(0),trnd(0),
date11(0),date12(0),time11(0),time12(0),TL1(0),
date21(0),date22(0),time21(0),time22(0),TL2(0),
date31(0),date32(0),time31(0),time32(0),TL3(0);
Array:hiVal[10](0),loVal[10](0),hiBar[10](0),loBar[10](0);
//hiVal[1]은 전고점, hiVal[2]는 전전고점, hiVal[3]은 전전전고점
//hiVal[0]은 변곡점 이후 현재봉까지의 고점. 현재 고점은 진행중이므로 계속 바뀐다.
//loVal[0]은 반대 개념
upRate = 1 + (chRate/100); //상승률
dnRate = 1 - (chRate/100); //하락률
for j = 1 to 9 { //전고,전저점을 9개까지 보관
loBar[j] = loBar[j] + 1; //전저점의 위치. 현재 봉으로부터 떨어져 있는 거리
hiBar[j] = hiBar[j] + 1; //전고점의 위치
}
if hiVal[0] <= H or hiVal[0] == 0 then { //전고,전저점 이후 현재까지의 고점
hiVal[0] = H; //0을 체크한 이유는 초기에 값이 없는 구간이 생기기 때문
hiBar[0] = 0; //현재 고점의 위치가 0이란 것은 현재봉의 고가가 구간 고점이라는 의미
}
else {
hiBar[0] = hiBar[0] + 1; //현재 고점의 위치
}
if loVal[0] >= L or loVal[0] == 0 then { //전고,전저점 이후 현재까지 저점
loVal[0] = L;
loBar[0] = 0;
}
else {
loBar[0] = loBar[0] + 1; //현재 구간 저점의 위치
}
if trnd != dnTr && hiVal[0] > H && hiVal[0] * dnRate > L then trnd = dnTr;
//저가가 고가 대비 변동률보다 밑으로 떨어지면 하락추세로 설정
//단, 현재봉의 고가가 변곡점 이후 최고가이면 상승 추세가 진행중이라고 본다.
//그래서 현재봉의 고가가 hiVal[0]보다 작다는 조건이 추가되었다.
else if trnd != upTr && loVal[0] < L && loVal[0] * upRate < H then trnd = upTr;
//고가가 저가 대비 변동률보다 높으면 상승추세로 설정
if trnd[1] == upTr and trnd == dnTr then { //상승추세였다가 하락추세로 바뀌었다면
for j = 8 downto 1 { //새로운 전고점이 생기는 것이므로
hiVal[j+1] = hiVal[j]; //전고점을 하나씩 뒤로 보낸다.
hiBar[j+1] = hiBar[j]; //전고점은 전전고점이 되고, 전전고점은 전전전고점이 된다.
}
hiVal[1] = hiVal[0]; //새로운 전고점에 현재 고점을 대입
hiBar[1] = hiBar[0];
hiVal[0] = H; //전고점이 확정되었으므로 전고점 이후 최고가는 현재봉의 고가
hiBar[0] = 0;
loVal[0] = L;
loBar[0] = 0;
//전고점이 새로 생긴 것이니까 전저점에서 전고점까지 추세선을 긋는다.
date11 = date[loBar[1]]; //추세선 시작일. 전저점의 날짜
time11 = stime[loBar[1]]; //추세선 시작시간
Value11 = loVal[1]; //추세선 시작가격
date12 = date[hiBar[1]]; //추세선 종료일. 전고점의 날짜
time12 = stime[hiBar[1]]; //추세선 종료시간
Value12 = hiVal[1]; //추세선 종료가격
TL1 = TL_New(date11,time11,Value11,date12,time12,Value12);
//TL_New는 신규 추세선을 그려주는 함수
}
if trnd[1] == dnTr and trnd == dnTr and //추세는 하락 상태에서 바뀌지 않았는데
hiVal[1] < hiVal[0] and //전고점보다 더 높은 고점이 출현했다면
hiVal[0] * dnRate > L then {
hiVal[1] = hiVal[0]; //전고점을 현재의 고점으로 바꿔준다.
hiBar[1] = hiBar[0];
hiVal[0] = H;
hiBar[0] = 0;
loVal[0] = L;
loBar[0] = 0;
//전고점이 추가된 게 아니고 바뀐 것이므로 종료일,종료시간,종료가격만 바꿔준다.
date12 = date[hiBar[1]]; //추세선 종료일
time12 = stime[hiBar[1]];
Value12 = hiVal[1];
TL_SetEnd(TL1, date12,time12,Value12);
//TL_SetEnd는 기존추세선의 종료지점을 변경해주는 추세선 함수이다.
//TL_Delete 함수를 써서 직전의 추세선을 지우고 다시 TL_New로 추세선을 추가해도 된다.
}
if trnd[1] == dnTr and trnd == upTr then { //추세가 하락에서 상승으로 바뀌었을 경우
for j = 8 downto 1 {
//이전저점은 전전저점으로, 전전저점은 전전전저점으로 번호를 부여
loVal[j+1] = loVal[j];
loBar[j+1] = loBar[j];
}
loVal[1] = loVal[0];
loBar[1] = loBar[0];
loVal[0] = L;
loBar[0] = 0;
hiVal[0] = H;
hiBar[0] = 0;
date11 = date[hiBar[1]]; //전저점이 새로이 생긴 것이므로 시작점은 전고점이 된다.
time11 = stime[hiBar[1]];
Value11 = hiVal[1];
date12 = date[loBar[1]];
time12 = stime[loBar[1]];
Value12 = loVal[1];
TL1 = TL_New(date11,time11,Value11,date12,time12,Value12);
}
if trnd[1] == upTr and trnd == upTr and //추세는 상승을 유지하고 있는데
loVal[1] > loVal[0] and //전저점보다 낮은 저가가 출현했다면
loVal[0] * upRate < H then {
loVal[1] = loVal[0]; //직전의 전저점만 바꿔준다.
loBar[1] = loBar[0];
loVal[0] = L;
loBar[0] = 0;
hiVal[0] = H;
hiBar[0] = 0;
date12 = date[loBar[1]];
time12 = stime[loBar[1]];
Value12 = loVal[1];
TL_SetEnd(TL1, date12,time12,Value12);
}
//여기까지가 파동선이고 아래는 추세선이다.
if loVal[2] < loVal[1] then {
//전전저점보다 전저점이 높을 경우
//전전저점으로부터 전저점까지 지지추세선을 긋는데
//시작점인 전전저점이 바뀌면 신규추세선을 긋고(TL_New)
//시작점이 바뀌지 않았다면 종료지점만 변경해준다(TL_SetEnd)
if loBar[2][1] + 1 != loBar[2][0] then {
//시작점이 바뀌었는지 여부는 가격은 동일할 수 있으므로 위치값으로 판별한다.
//위치값은 1씩 증가시켜왔으므로 이전 봉에서의 위치값이 1 차이나는지로 확인
//1 이상 차이가 나면 전전고점이 바뀐 것으로 보고 추세선을 추가로 그린다.
date21 = date[loBar[2]];
time21 = stime[loBar[2]];
Value21 = loVal[2];
date22 = date[0]; //추세선이므로 현재 봉까지 그려준다.
time22 = stime[0];
Value22 = (loVal[1]-loVal[2])/(loBar[2]-loBar[1])*loBar[2]+LoVal[2];
//종료시점의 가격은 직선의 기울기와 절편을 계산해서 구한다.
TL2 = TL_New(date21,time21,Value21,date22,time22,Value22);
}
else {
//전전저점이 바뀌지 않았다면 종료시점만 변경하면 된다.
date22 = date[0];
time22 = stime[0];
Value22 = (loVal[1]-loVal[2])/(loBar[2]-loBar[1])*loBar[2]+LoVal[2];
TL_SetEnd(TL2, date22,time22,Value22);
//TL_SetExtRight 함수는 추세선을 오른쪽으로 연장하는 함수인데
//이 함수를 사용하면 모든 추세선이 현재봉까지 연장되어 알아볼 수가 없다.
}
}
if hiVal[2] > hiVal[1] then {
if hiBar[2][1] + 1 != hiBar[2][0] then {
date31 = date[hiBar[2]];
time31 = stime[hiBar[2]];
Value31 = hiVal[2];
date32 = date[0];
time32 = stime[0];
Value32 = (hiVal[1]-hiVal[2])/(hiBar[2]-hiBar[1])*hiBar[2]+hiVal[2];
TL3 = TL_New(date31,time31,Value31,date32,time32,Value32);
}
else {
date32 = date[0];
time32 = stime[0];
Value32 = (hiVal[1]-hiVal[2])/(hiBar[2]-hiBar[1])*hiBar[2]+hiVal[2];
TL_SetEnd(TL3, date32,time32,Value32);
}
}
if trnd == upTr and loVal[2] > loVal[1] then
TL_SetColor(TL1,BLUE);
else if trnd == dnTr and hiVal[2] < hiVal[1] then
TL_SetColor(TL1,RED);
else
TL_SetColor(TL1,BLACK);
TL_SetSize(TL1,2);
TL_SetColor(TL2,RED);
TL_SetColor(TL3,BLUE);
2015-12-30
284
글번호 93930
답변완료
일간갭보정관련문의드립니다
안녕하세요
당일거래용으로 수식을 만들어 시물레이션을 해보면 일간갭보정에 체크를 하고 시물레이션을
한 결과 값과 갭보정을 하지않고 시물레이션을 한 결과값에 차이가 나는데 어떤값이
더 신뢰성이 있는 값인가요?
일간 갭보정에 체크하고 시물레이션을 한 결과값은 실행챠트에서 일간 갭보정란에 체크를
하고 사용하면 유사한 결과값을 얻을수 있는건지 궁금합니다.
2015-12-30
138
글번호 93929
답변완료
수식좀 부탁합니다
안녕하세요. 내일만 지나면 새해네요..
먼저 인사드릴께요. 새해 복많이 받으세요...항상 고맙습니다.
아래 수식은 상승시 거래량과 하락시 거래량의 편차를 이용하여 지표를 만들고자 했습니다. 제가 프로그램을 잘몰라서 부족한 부분이 많습니다. 잘못된점 좀 수정해주세요.
조건: 대량거래량(1000) 이상을 만족하면서 상승체결횟수와 대량거래량 이상이면서 하락체결횟수의 차이를 알고자 합니다.
질문
1. 대량거래량 이상 이라는 조건을 넣었음에도 상승체걸횟수와 하락체결횟수 결과값과 차이가 없는데..어느부분이 잘못 되었을까요?
2. COUNTIF 수식은 일정기간동안 조건을 만족하는 횟수를 알 수 있는 함수인데.. 일정기간이 아니 당 캔들상 조건을 만족하는 횟수를 알 수 있는 수식좀 부탁드립니다.
----------------------------------------------------------------------------------------
INPUT : 단기(5), 기준(10), 중기(18), 대량거래량(1000);
VAR : UP(0), DW(0), CON1(FALSE), CON2(FALSE), A(0), B(0), C(0), D(0), E(0), F(0),단기OS(0), 기준OS(0), 중기OS(0);
UP=AVG(UPVOL[1], UPVOL[2], UPVOL[3], UPVOL[4], UPVOL[5], UPVOL[6], UPVOL[7], UPVOL[8], UPVOL[9], UPVOL[10]+UPVOL[11], UPVOL[12], UPVOL[13], UPVOL[14], UPVOL[15], UPVOL[16], UPVOL[17], UPVOL[18]);//상승시 거래량 기준값
DW=AVG(DOWNVOL[1], DOWNVOL[2], DOWNVOL[3], DOWNVOL[4], DOWNVOL[5], DOWNVOL[6], DOWNVOL[7], DOWNVOL[8], DOWNVOL[9], DOWNVOL[10]+DOWNVOL[11], DOWNVOL[12], DOWNVOL[13], DOWNVOL[14], DOWNVOL[15], DOWNVOL[16], DOWNVOL[17], DOWNVOL[18]); //하락시 거래량 기준값
CON1=UPVOL>대량거래량 AND UPVOL>AVG(UP,DW); // 상승조건
CON2=DOWNVOL>대량거래량 AND DOWNVOL>AVG(UP,DW); //하락조건
AA =COUNTIF(CON1==TRUE, 단기); // 단기동안 상승조건을 만족한 횟수
BB =COUNTIF(CON2==TRUE, 단기); // 단기동안 하락조건을 만족한 횟수
CC =COUNTIF(CON1==TRUE, 기준); // 기준동안 상승조건을 만족한 횟수
DD =COUNTIF(CON2==TRUE, 기준); // 기준동안 하락조건을 만족한 횟수
EE =COUNTIF(CON1==TRUE, 중기); // 중기동안 상승조건을 만족한 횟수
FF =COUNTIF(CON2==TRUE, 중기); // 중기동안 하락조건을 만족한 횟수
단기OS = AA-BB; //단기 동안 상승조건을 만족한 횟수와 하락조건을 만족한 횟수
기준OS = CC-DD; //기준 동안 상승조건을 만족한 횟수와 하락조건을 만족한 횟수
중기OS = EE-FF; //중기 동안 상승조건을 만족한 횟수와 하락조건을 만족한 횟수
IF 단기OS >0 THEN PLOT1( 단기OS, "+단기OS" ); ELSE IF 단기OS <0 THEN PLOT2(단기OS, "-단기OS" ); ELSE NoPlot(1);
IF 기준OS>0 THEN PLOT3(기준OS, "+기준OS"); ELSE IF 기준OS <0 THEN PLOT4(기준OS, "-기준OS"); ELSE NoPlot(1);
IF 중기OS>0 THEN PLOT5(중기OS, "+중기OS"); ELSE IF 중기OS <0 THEN PLOT6(중기OS, "-중기OS"); ELSE NoPlot(1);
2015-12-30
161
글번호 93928