커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1536
글번호 230811
답변완료
부탁드립니다.
1>
아래 수식에 그림처럼 최고가 연결선. 최저가 (분홍색으로) 연결선 부탁드립니다.
var : clr(0);
var1 = Data7(c);
if var1 >= 0 and var1 < 1000 Then
clr = Pink;
if var1 >= 1000 and var1 < 2000 Then
clr = rgb(251, 188, 101);
if var1 >= 2000 and var1 < 3000 Then
clr = Orange;
if var1 >= 3000 and var1 < 4000 Then
clr = Red;
if var1 >= 5000 Then
clr = Magenta;
if var1 < 0 and var1 > -1000 Then
clr = Green;
if var1 <= -1000 and var1 > -2000 Then
clr = rgb(118, 220, 234);
if var1 <= -2000 and var1 > -3000 Then
clr = Cyan;
if var1 <= -3000 and var1 > -4000 Then
clr = Blue;
if var1 <= -5000 Then
clr = Black;
Plot1(var1,"지표",clr);
2> 아래수식에 점선의 가로선을 넣어주세요
300, 700, 1000
-300. -700, -1000
var : clr(0);
var1 = Data5(c)-data6(c);
if var1 >= 0 and var1 < 200 Then
clr = Pink;
if var1 >= 200 and var1 < 500 Then
clr = Orange;
if var1 >= 500 and var1 < 1000 Then
clr = Red;
if var1 >= 1000 Then
clr = Magenta;
if var1 < 0 and var1 > -200 Then
clr = Green;
if var1 <= -200 and var1 > -500 Then
clr = rgb(118, 220, 234);
if var1 <= -500 and var1 > -1000 Then
clr = Blue;
if var1 <= -1000 Then
clr = Black;
Plot1(var1,"지표",clr);
2025-07-15
319
글번호 192511
답변완료
키움에서의 합산수식을 구현하고싶습니다.
수고하십니다.
아래의 키움에서의 합산수식을 구현코져 합니다.
B=sum(C,기간,시작봉) ;
시작봉=1 ;
B 수식이 키움에서 1봉전 기준으로 기간만큼의 합산 수식인데
이 수식을 도와주십시요. 수고하세요!!
2025-07-15
262
글번호 192503
답변완료
문의 드립니다.
매수 후 매수가를 아래로 돌파시 매도 청산되도록 추가 부탁드립니다.
input : Price(429.40),xPrice(432.00);
if crossup(C,price) Then
buy();
if CrossDown(C,xPrice) Then
ExitLong();
매도 후 매도가를 위로 돌파시 매수 청산되도록 추가 부탁드립니다.
input : Price(428.50),xPrice(429.50);
if crossup(C,price) Then
Sell();
if CrossDown(C,xPrice) Then
ExitShort();
2025-07-15
204
글번호 192502
답변완료
조건검색식 문의 드립니다
저가가 엔벨로프 하단선 아래에 위치하는 조건식 문의드립니다.
2025-07-15
215
글번호 192500
답변완료
문의드립니다
안녕하세요?
1.아래수식에서 현재 신호가 발생하고있는 봉의 직전봉이
이전100개봉의 최저가이면 매수
이전100개봉의 최고가이면 매도 란 조건을 추가 원합니다
2.아래수식에서 현재 신호가 발생하고있는 봉의 직전봉또는 전전봉이
이전100개봉의 최저가이면 매수
이전100개봉의 최고가이면 매도 란 조건을 추가 원합니다
감사합니다
if T == 1 and T != T[1] Then
Buy("매수");
if T == -1 and T != T[1] Then
Sell("매도");
2025-07-15
215
글번호 192499
장대박 님에 의해서 삭제되었습니다.
2025-07-14
21
글번호 192498
답변완료
수정을 부탁 드립니다.
안녕하세요!
아래 수식은 두종목의 가격차이를 실시간으로 텍스트로 보여주는 수식인데요!
ㅁ매매를 하면서 보면 두 종목의 가격차이가 실시간으로 잘 안맞는 것 같아서
확인 한번 부탁드립니다.
var : ii(0,Data1),mm(0,Data1),dd(0,data1),tl1(0,Data1),tl2(0,Data1),tx1(0,Data1);
mm = (Data1(c)+data2(c))/2;
dd = (Data1(c)-data2(c));
if CurrentDate == sDate Then
{
if Data1(sDate != sDate[1])Then
{
tl1 = TL_New(sDate,stime,Data1(c),NextBarSdate,NextBarStime,Data1(c));
TL_SetExtLeft(tl1,true);
TL_SetExtRight(tl1,true);
TL_SetColor(tl1,Lime);
tl2 = TL_New(sDate,stime,Data2(c),NextBarSdate,NextBarStime,Data2(c));
TL_SetExtLeft(tl2,true);
TL_SetExtRight(tl2,true);
TL_SetColor(tl2,Magenta);
Tx1 = Text_New(sDate,sTime,mm,NumToStr(dd,2));
Text_SetStyle(tx1,0,2);
}
Else
{
TL_SetBegin(tl1,sDate,sTime,Data1(c));
TL_SetEnd(tl1,NextBarSdate,NextBarStime,Data1(c));
TL_SetBegin(tl2,sDate,sTime,Data2(c));
TL_SetEnd(tl2,NextBarSdate,NextBarStime,Data2(c));
Text_SetLocation(tx1,NextBarSdate,NextBarStime,mm);
}
}
2025-07-14
220
글번호 192497
답변완료
수식 수정을 부탁드립니다
수식 검증에 이상이 없고 시스템에 저장되어 있는데 챠트에 적용하면 수식이 보이지 않고 구현되지도 않습니다. 도움을 부탁드립니다. 늘 건강하세요.
Inputs: rsiPeriod(21), bandLength(34), lengthrsipl(7), lengthtradesl(2);
// --------------------------------------------------------------------------------
// 변수 선언 (cnt 변수 추가)
Var: A_VWAP_1min(0);
Var: B_VWAP_1min(0);
Var: C_VWAP_1min(0);
Var: rsiVal_1min(0);
Var: S_RSI_Val_1min(0);
Var: F_RSI_Val_1min(0);
Var: HH_5min(0), LL_5min(0), CC_5min(0);
Var: TF_5min(0);
Var: A_VWAP_5min(0);
Var: B_VWAP_5min(0);
Var: C_VWAP_5min(0);
Var: rsiVal_5min(0);
Var: S_RSI_Val_5min(0);
Var: F_RSI_Val_5min(0);
Var: HH_10min(0), LL_10min(0), CC_10min(0);
Var: TF_10min(0);
Var: A_VWAP_10min(0);
Var: B_VWAP_10min(0);
Var: C_VWAP_10min(0);
Var: rsiVal_10min(0);
Var: S_RSI_Val_10min(0);
Var: F_RSI_Val_10min(0);
Var: cnt(0); // <-- 여기에 cnt 변수 선언 추가
Array : HH_5min_Arr[61](0),LL_5min_Arr[61](0),CC_5min_Arr[61](0);
Array : HH_10min_Arr[61](0),LL_10min_Arr[61](0),CC_10min_Arr[61](0);
// --------------------------------------------------------------------------------
// 1. 1분봉 데이터 (현재 차트) - 기존 코드의 변수명 그대로 사용
// 1분봉 VWAP 및 RSI 계산
A_VWAP_1min = Average((H+L+C)/3, 5);
B_VWAP_1min = Average((H+L+C)/3, 20);
C_VWAP_1min = Average((H+L+C)/3, 60);
rsiVal_1min = RSI(rsiPeriod);
S_RSI_Val_1min = Average(rsiVal_1min, lengthrsipl);
F_RSI_Val_1min = Average(rsiVal_1min, lengthtradesl);
// --------------------------------------------------------------------------------
// 2. 5분봉 데이터 구성 및 VWAP, RSI 계산
TF_5min = TimeToMinutes(stime)%5; // 5분봉의 시작을 감지
if dayindex == 0 or (TF_5min < TF_5min[1] and stime > stime[1]) Then{ // 5분봉 시작 시 초기화
HH_5min_Arr[0] = H;
LL_5min_Arr[0] = L;
CC_5min_Arr[0] = C;
for cnt = 1 to 60{ // <-- cnt 사용
HH_5min_Arr[cnt] = HH_5min_Arr[cnt-1][1];
LL_5min_Arr[cnt] = LL_5min_Arr[cnt-1][1];
CC_5min_Arr[cnt] = CC_5min_Arr[cnt-1][1];
}
}
// 5분봉 내에서 고가, 저가 업데이트 (현재 5분봉이 진행 중일 때)
if H > HH_5min_Arr[0] Then HH_5min_Arr[0] = H;
if L < LL_5min_Arr[0] Then LL_5min_Arr[0] = L;
CC_5min_Arr[0] = C; // 현재 5분봉의 종가는 항상 현재 1분봉의 종가
// 이 부분은 예스트레이더의 Average 함수가 다른 시간대의 데이터를 인자로 받아 처리하는지,
// 아니면 직접 5분봉 데이터를 기반으로 Average를 구현해야 하는지에 따라 달라집니다.
// --------------------------------------------------------------------------------
// 3. 10분봉 데이터 구성 및 VWAP, RSI 계산
TF_10min = TimeToMinutes(stime)%10; // 10분봉의 시작을 감지
if dayindex == 0 or (TF_10min < TF_10min[1] and stime > stime[1]) Then{ // 10분봉 시작 시 초기화
HH_10min_Arr[0] = H;
LL_10min_Arr[0] = L;
CC_10min_Arr[0] = C;
for cnt = 1 to 60{ // <-- cnt 사용
HH_10min_Arr[cnt] = HH_10min_Arr[cnt-1][1];
LL_10min_Arr[cnt] = LL_10min_Arr[cnt-1][1];
CC_10min_Arr[cnt] = CC_10min_Arr[cnt-1][1];
}
}
// 10분봉 내에서 고가, 저가 업데이트
if H > HH_10min_Arr[0] Then HH_10min_Arr[0] = H;
if L < LL_10min_Arr[0] Then LL_10min_Arr[0] = L;
CC_10min_Arr[0] = C;
// --------------------------------------------------------------------------------
// 4. 최종 매수/매도 조건 (모든 시간대 만족 시)
// 이 부분은 위에서 구성된 5분봉, 10분봉의 VWAP 및 RSI 변수들을 사용하여 조건을 만듭니다.
// 아직 5분봉, 10분봉의 VWAP 및 RSI 계산 로직이 없으므로 이 부분은 주석 처리 또는 임시 값 사용 필요
// If (A_VWAP_1min > B_VWAP_1min and B_VWAP_1min > C_VWAP_1min and F_RSI_Val_1min > S_RSI_Val_1min) And
// (A_VWAP_5min > B_VWAP_5min and B_VWAP_5min > C_VWAP_5min and F_RSI_Val_5min > S_RSI_Val_5min) And
// (A_VWAP_10min > B_VWAP_10min and B_VWAP_10min > C_VWAP_10min and F_RSI_Val_10min > S_RSI_Val_10min) Then
// Buy("매수");
// If (A_VWAP_1min < B_VWAP_1min and B_VWAP_1min < C_VWAP_1min and F_RSI_Val_1min < S_RSI_Val_1min) And
// (A_VWAP_5min < B_VWAP_5min and B_VWAP_5min < C_VWAP_5min and F_RSI_Val_5min < S_RSI_Val_5min) And
// (A_VWAP_10min < B_VWAP_10min and B_VWAP_10min < C_VWAP_10min and F_RSI_Val_10min < S_RSI_Val_10min) Then
// Sell("매도");
2025-07-14
264
글번호 192496
답변완료
부탁드립니다.
도움에 감사 드립니다.
월이 바뀌면 새로 계산하는 방식으로 수정 부탁 드립니다.
미리 감사 드립니다.
input:renkoSize(0.5),length(10), NumATRs(1.5);
var:j(0),k(0),renkoCnt(0),gubun(0),Sum(0),mav(0);
array:OO[50](0),HH[50](0),LL[50](0),CC[50](0); //이평선
If bdate != bdate[1] and DayOfWeek(Bdate) <= DayOfWeek(Bdate[1]) Then //break on session에 해당, 즉 일자가 바뀌면 새로 계산
{
gubun = 0; //방향을 초기화한다. 이후 형성되는 가격에 의해 방향이 계산
For j = 49 DownTo 1 //금일 시가봉을 신규 추가
{
OO[j] = OO[j-1];
HH[j] = HH[j-1];
LL[j] = LL[j-1];
CC[j] = CC[j-1];
}
OO[0] = C; //분봉의 종가를 기반으로 계산하기 때문에 당일 시초가 아니다
HH[0] = C;
LL[0] = C;
CC[0] = C;
}
Else
{
If gubun == 0 and CC[0] > 0 Then //일 첫봉이 완성되지 않은 시점
{
If OO[0] - renkoSize >= C Then
{
gubun = -1; //하락 방향
CC[0] = OO[0] - renkoSize; //음봉
HH[0] = OO[0];
LL[0] = CC[0];
j = 0;
}
Else If OO[0] + renkoSize <= C Then
{
gubun = 1; //상승 방향
CC[0] = OO[0] + renkoSize; //양봉
HH[0] = CC[0];
LL[0] = OO[0];
j = 0;
}
}
If LL[0] - renkoSize >= C Then
{
gubun = -1;
renkoCnt = Int(Round((LL[0]-C)/renkoSize,9));
if renkoCnt > 49 then renkoCnt = 49;
For j = 49 DownTo renkoCnt
{
OO[j] = OO[j-renkoCnt];
HH[j] = HH[j-renkoCnt];
LL[j] = LL[j-renkoCnt];
CC[j] = CC[j-renkoCnt];
}
For j = renkoCnt-1 DownTo 0
{
OO[j] = LL[j+1];
CC[j] = LL[j+1] - renkoSize;
HH[j] = OO[j];
LL[j] = CC[j];
}
}
Else If HH[0] + renkoSize <= C Then
{
gubun = 1;
renkoCnt = Int(Round((C-HH[0])/renkoSize,9));
if renkoCnt > 49 then renkoCnt = 49;
For j = 49 DownTo renkoCnt
{
OO[j] = OO[j-renkoCnt];
HH[j] = HH[j-renkoCnt];
LL[j] = LL[j-renkoCnt];
CC[j] = CC[j-renkoCnt];
}
For j = renkoCnt-1 DownTo 0
{
OO[j] = HH[j+1];
CC[j] = HH[j+1] + renkoSize;
HH[j] = CC[j];
LL[j] = OO[j];
}
}
Else If nextbarBdate != Bdate and DayOfWeek(nextbarBdate) <= dayofweek(Bdate) Then //주 마지막봉
{
For j = 49 DownTo 1
{
OO[j] = OO[j-1];
HH[j] = HH[j-1];
LL[j] = LL[j-1];
CC[j] = CC[j-1];
}
If LL[1] > C Then { //종가가 이전 봉보다 아래 형성
OO[0] = LL[1];
CC[0] = C;
HH[0] = OO[0];
LL[0] = CC[0];
} Else If HH[1] < C Then { //종가가 이전 봉보다 위에 형성
OO[0] = HH[1];
CC[0] = C;
HH[0] = CC[0];
LL[0] = OO[0];
} Else { //종가가 이전 봉의 중간에 형성
OO[0] = C;
CC[0] = C;
HH[0] = C;
LL[0] = C;
}
j = 0; //채널 값을 새로이 계산
}
}
if CC[length] > 0 then
{
sum = 0 ;
for j = 0 to length - 1
{
sum = sum + CC[j];
}
mav = sum/length;
plot5(maV,"MidLine");
}
2025-07-14
227
글번호 192495