커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
5436
글번호 230811
답변완료
문의 드립니다.
항상 노고에 감사드립니다. 두가지 질문이 있습니다. 답변 부탁드립니다.
print 함수 사용법 관련 질문드립니다.
예를들어 print 함수로 call 270 과 call 272.5 종목을 csv 파일로 저장을 하려고 할때 발생하는 문제에 대한 질문들입니다.
1. 각 종목명을 파일명으로 자동 저장하게 할 수는 없는지요
종목 코드를 반환하는
var : Code("");
Code = SymbolCode;
를 이용해서 가능할 줄 알고
print("c:₩ %s .csv","%.2f, %.2f, %.2f, %.2f", code , data1(open), data1(high), data1(low), data1(close) );
이런 식으로 했는데 안되네요 ㅠㅠ
2. 그리고 주 종목으로 call 270을 놓고 타주기 참조종목으로 call 272.5 종목을 불러와서
1초 데이타를 저장한다고 할 때
data1(close)와 data2(close)를 print 하면 주종목이 거래가 있던 시간봉(여기서는1초봉)
에 대해서만 data2의 print 값이 이상하게 print 되는 것을 확인 할 수 있었습니다.
혹시 이 문제를 해결할 수 없는지요?
감사합니다.
답변 부탁드립니다.
2019-12-12
215
글번호 134341
답변완료
문의드립니다
안녕하세요~ 다시 문의드립니다
var : T3(0);
var12 = ma(C,50);
var13 = ma(C,80);
var14 = var12-var13;
var15 = -var14;
input : short2(12),long2(26),sig2(9);
var : MACDV01(0),MACDS01(0);
MACDV01 = MACD(short2,long2);
MACDS01 = WMA(MACDV01,sig2);
if crossup(var14,var15) or CrossDown(var14,var15) Then
{
value18 = value17[1];
}
if var14 > 0 and var14 > var14[1] Then
value17 = var14;
if var14 < var15 and var15 > var15[1] Then
value17 = var15;
if crossup(var14,0) Then
T3 = 1;
if CrossDown(var14,0) Then
T3 = -1;
if (T3 == 1 and var14 >= value18) and MACDV01 > MACDS01 then
{
T3 = 2;
buy();
}
if CrossDown(var12,var13) Then
ExitLong();
if (T3 == -1 and var15 >= value18) and MACDV01 < MACDS01 Then
{
T3 = -2;
sell();
}
if CrossUp(var12,var13) Then
ExitShort();
1. 첨부파일 그림처럼 밀려서 신호가 나옵니다ㅠ
전제조건인 앞 고점보다 클때, 딱 그시점에서만 다른조건이랑 맞으면 진입하고 다른조건이 안맞으면 신호가 없도록 수정해 주시면 좋겠습니다.
크로스업 크로스다운처럼 특정 시점으로 딱 지정할수는 없을까요?
2. 재상승해서 앞 고점보다 클때도 여전히 신호가 나오는데(첫상승에 다른조건 안맞아서 신호 없다가 재상승때 신호) 처음 상승일때만 신호가 나오도록 같이 부탁드릴게요. 첨부파일에서 뒤에 신호가 그렇네요. 1번 내용에 추가해서 따로 부탁드릴게요. 혹시 이부분은 설명 달아주시면 제가 다른 조건 추가해서 수정해보겠습니다
2번이 힘들다면 처음 1번 내용만큼은 꼭 부탁드리겠습니다
즐거운 주말 보내세요~
2019-12-12
213
글번호 134340
답변완료
만기일 강제청산 안된 신호상 잔고
[상황]
-15분봉이고, 봉은 봉시작 시간으로 표시되게 사용 중입니다.
-선물에서 강제청산 탭으로 15:35에 당일청산을 사용해오던 중, 선물옵션만기일은 실제 거래시간종료가 15:20이라서 할 수 없이 강제청산탭에 15:19분으로 설정하여 실제 강제 청산되서 실잔고는 없는 상황입니다.
[질문]
-만기일 다음날 원래 사용해오던 강제청산탭 15:35분으로 원위치 설정하니, 신호상 미청산 잔고가 남게 되네요.(매수잔고; 수익 상태이고 손절라인에 걸리지 않아서~)
-이럴 경우 신호상 미청산 매수잔고로 인해 만기일 다음날은 엇박자가 나게 생겼는데, 시스템수식적으로 처리할 방법은 없나요?
- if bdate != bdate[1] Then
{
"기존 사용 수식"
}
으로 넣어봤더니 안되는데 biz date 이해를 잘못했나 봅니다. ㅠ.ㅠ
항상 도움에 감사드리며~~
2019-12-12
359
글번호 134339
답변완료
특정가격 n봉동안 모니터링
수식에 의해 도출된 진입희망가격이 나온다음에,
진입희망가격이 나온 뒤, n봉간 모니터링 하면서 그 가격에 도달하는경우 매수 혹은 매도 주문을 내는 로직을 구현하고 싶습니다.
예를들어
크루드오일 매수 진입희망가격이 50.00 이 나온 뒤,
n봉 내에서 50.00에 도달하는 경우 atstop 매수 주문
n봉 내에서 50.00에 도달하지 못하는 경우 매수주문 하지 않고 다음진입희망 가격을 찾는 로직으로 돌아감.
크루드오일 매도 진입희망가격이 45.00 이 나온 뒤,
n봉 내에서 45.00에 도달하는 경우 atstop 매도 주문
n봉 내에서 45.00에 도달하지 못하는 경우 매도주문 하지 않고 다음진입희망 가격을 찾는 로직으로 돌아감.
구현이 가능하다면 도움 부탁드립니다.
2019-12-12
214
글번호 134338
답변완료
부탁드립니다
수고하십니다
65249번 재질문 입니다
분홍색점 주홍색점 걸리는점 이외에 점들은 백색점 으로부탁드립니다
2019-12-12
196
글번호 134337
답변완료
키움 수식 변환점요
eavg(eavg(amount(1)/v(1)*1000000))
ma 로 바꾸면 숫자를 넣으라고 하네요 키움에서는 그냥 이렇게 해도 그래프가 나오는데
2019-12-12
308
글번호 134336
답변완료
호가잔량 표시 고저파동식
안녕하세요
아래 파동식 고저점에 고저점지수와 함께 호가잔량이 표시되도록 부탁드립니다
Input:전환비율(0.05),종가사용여부(0),파동선두께(2),수치표시(1),Left(5),right(5);
Var:j(0),jj(0), HH(0),LL(0),hiBar(0),loBar(0),최종꼭지점(""),처리구분(""),
TL1(0),Text1(0),Tx(0),순호잔(0);
Array:고[10,4](0),저[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime
순호잔 = bids - asks;
HH = IFF(종가사용여부 == 1,C,H);
LL = IFF(종가사용여부 == 1,C,L);
If Index == 0 Then
{
고[1,1] = HH;
고[1,2] = 0;
고[1,3] = sDate;
고[1,4] = sTime;
저[1,1] = LL;
저[1,2] = 0;
저[1,3] = sDate;
저[1,4] = sTime;
}
If Index > 0 Then // Index가 0일때는 이전 봉이 없으므로 Index가 1일때부터 1씩 증가
{
hiBar = hiBar + 1; // 최고점을 찍은 고[저]가의 위치를 저장 해놓기 위해 봉번호를 카운트한다.
loBar = loBar + 1;
}
If HH[hiBar] < HH Then hiBar = 0; // 현재 봉이 최고가이면 봉번호를 0으로 초기화
If LL[loBar] > LL Then loBar = 0;
Condition1 = 저[1,1] * (1 + (전환비율/100)) < HH and hiBar == 0;
// 전저점에서 최소변동률만큼 더한 값보다 고가가 크다면 추세가 변한 것으로 보고 신규 고점으로 인식
Condition2 = 고[1,1] * (1 - (전환비율/100)) > LL and loBar == 0;
// 전고점에서 최소변동률만큼 뺀 값보다 저가가 작다면 추세가 변한 것으로 보고 신규 저점으로 인식
처리구분 = "";
If Condition1 and Condition2 Then // 고점과 저점 조건 동시 만족
{
If 최종꼭지점 == "저점" Then
{
If 저[1,1] > LL Then 처리구분 = "저점처리";
Else 처리구분 = "고점처리";
}
Else If 최종꼭지점 == "고점" Then
{
If 고[1,1] < HH Then 처리구분 = "고점처리";
Else 처리구분 = "저점처리";
}
}
Else If Condition1 Then 처리구분 = "고점처리";
Else If Condition2 Then 처리구분 = "저점처리";
#==========================================#
If 처리구분 == "고점처리" Then
{
If 최종꼭지점 == "저점" Then
{
For j = 10 DownTo 2
{
For jj = 1 To 4
{
고[j,jj] = 고[j-1,jj];
}
}
고[1,1] = HH[hiBar];
고[1,2] = Index - hiBar;
고[1,3] = sDate[hiBar];
고[1,4] = sTime[hiBar];
hiBar = -1;
// 다음 봉의 고가가 기준 고가로 인식되려면 hiBar 값이 0이 되어야 한다.
// 봉이 바뀔 때마다 hiBar의 값을 1씩 증가시키므로 다음 봉의 hiBar 값은 0이 된다.
loBar = -1;
TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]);
If 수치표시 == 1 Then
{
Text1 = Text_New(고[1,3],고[1,4],고[1,1],NumToStr(고[1,1],2));
Text_SetStyle(Text1, 2, 1);
Text_SetColor(Text1,YELLOW);
Text_SetSize(Text1, 12);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,BLACK);
}
Else If 고[1,1] < HH[hiBar] Then // 1번 고점보다 높은 고가 출현
{
고[1,1] = HH[hiBar];
고[1,2] = Index - hiBar;
고[1,3] = sDate[hiBar];
고[1,4] = sTime[hiBar];
hiBar = -1;
loBar = -1;
TL_SetEnd(TL1,고[1,3],고[1,4],고[1,1]);
// 시작점은 변동없고 끝점의 위치가 현재 봉으로 연장된 것임
If 수치표시 == 1 Then
{
Text_SetLocation(Text1,고[1,3],고[1,4],고[1,1]);
Text_SetString(Text1,NumToStr(고[1,1],2));
}
}
최종꼭지점 = "고점";
}
#==========================================#
If 처리구분 == "저점처리" Then
{
If 최종꼭지점 == "고점" Then
{
For j = 10 DownTo 2
{
For jj = 1 To 4
{
저[j,jj] = 저[j-1,jj];
}
}
저[1,1] = LL[loBar];
저[1,2] = Index - loBar;
저[1,3] = sDate[loBar];
저[1,4] = sTime[loBar];
hiBar = -1;
loBar = -1;
TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]);
If 수치표시 == 1 Then
{
Text1 = Text_New(저[1,3],저[1,4],저[1,1],NumToStr(저[1,1],2));
Text_SetStyle(Text1, 2, 0);
Text_SetColor(Text1,CYAN);
Text_SetSize(Text1, 12);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,BLACK);
}
Else If 저[1,1] > LL[loBar] Then
{
저[1,1] = LL[loBar];
저[1,2] = Index - loBar;
저[1,3] = sDate[loBar];
저[1,4] = sTime[loBar];
hiBar = -1;
loBar = -1;
TL_SetEnd(TL1,저[1,3],저[1,4],저[1,1]);
If 수치표시 == 1 Then
{
Text_SetLocation(Text1,저[1,3],저[1,4],저[1,1]);
Text_SetString(Text1,NumToStr(저[1,1],2));
}
}
최종꼭지점 = "저점";
}
그리고 참고로 전에 작성된 스윙고저점 호가잔량표시수식입니다 참고부탁드립니다
input : Left(5),right(5);
var : Tx(0),순호잔(0);
순호잔 = bids - asks;
if SwingHigh(1,H,Left,right,left+right+1) != -1 Then
{
tx = Text_New(sdate[right],stime[right],H[right],"순호잔 : "+NumToStr(순호잔,0));
Text_SetStyle(tx,2,1);
}
if SwingLow(1,L,Left,right,left+right+1) != -1 Then
{
tx = Text_New(sdate[right],stime[right],L[right],"순호잔 : "+NumToStr(bids,0));
Text_SetStyle(tx,2,0);
}
2019-12-12
266
글번호 134335
답변완료
문의 드립니다.
도움에 감사 드립니다.
다음 수식에서 지표의
black이 green으로 모두 바뀌면 매수 진입
green이 black으로 모두 바뀌면 청산과 매도 진입하도록 부탁 드립니다.
미리 감사 드립니다.
input:P1(20);
input:P1_증가(10);
var : cnt(0);
Array : VV[10](0);
for cnt = 1 to 9
{
vv[cnt] =ema(c,(P1 + (cnt-1)*P1_증가));
}
if vv[1]>vv[1][1] then
plot1(vv[1],"1" ,green);
else
plot1(vv[1],"1" ,black);
if vv[2]>vv[2][1] then
plot2(vv[2],"2" ,green);
else
plot2(vv[2],"2" ,black);
if vv[3]>vv[3][1] then
plot3(vv[3],"3" ,green);
else
plot3(vv[3],"3" ,black);
if vv[4]>vv[4][1] then
plot4(vv[4],"4" ,green);
else
plot4(vv[4],"4" ,black);
if vv[5]>vv[5][1] then
plot5(vv[5],"5" ,green);
else
plot5(vv[5],"5" ,black);
2019-12-12
191
글번호 134330
답변완료
부탁 드립니다.
도움에 감사 드립니다.
그림과 같이 부탁 드립니다.
미리 감사 드립니다.
2019-12-12
228
글번호 134323