커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
3544
글번호 230811
답변완료
특정가격 n봉동안 모니터링
수식에 의해 도출된 진입희망가격이 나온다음에,
진입희망가격이 나온 뒤, n봉간 모니터링 하면서 그 가격에 도달하는경우 매수 혹은 매도 주문을 내는 로직을 구현하고 싶습니다.
예를들어
크루드오일 매수 진입희망가격이 50.00 이 나온 뒤,
n봉 내에서 50.00에 도달하는 경우 atstop 매수 주문
n봉 내에서 50.00에 도달하지 못하는 경우 매수주문 하지 않고 다음진입희망 가격을 찾는 로직으로 돌아감.
크루드오일 매도 진입희망가격이 45.00 이 나온 뒤,
n봉 내에서 45.00에 도달하는 경우 atstop 매도 주문
n봉 내에서 45.00에 도달하지 못하는 경우 매도주문 하지 않고 다음진입희망 가격을 찾는 로직으로 돌아감.
구현이 가능하다면 도움 부탁드립니다.
2019-12-12
179
글번호 134338
답변완료
부탁드립니다
수고하십니다
65249번 재질문 입니다
분홍색점 주홍색점 걸리는점 이외에 점들은 백색점 으로부탁드립니다
2019-12-12
166
글번호 134337
답변완료
키움 수식 변환점요
eavg(eavg(amount(1)/v(1)*1000000))
ma 로 바꾸면 숫자를 넣으라고 하네요 키움에서는 그냥 이렇게 해도 그래프가 나오는데
2019-12-12
279
글번호 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
236
글번호 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
163
글번호 134330
답변완료
부탁 드립니다.
도움에 감사 드립니다.
그림과 같이 부탁 드립니다.
미리 감사 드립니다.
2019-12-12
202
글번호 134323
답변완료
코스닥선물에서 오늘 거래량이 만계약인데 미결재약정은 어떻게 4만계약이 넘나요?
코스닥선물에서 오늘 거래량이 만계약인데 미결재약정은 어떻게 4만계약이 넘나요?
2019-12-12
170
글번호 134319
답변완료
부탁드립니다
수고하십니다
1번 수식
input : Period(10),Period1(0);
Var : value(0),tx1(0),tx2(0),tx3(0),tx4(0),tx5(0),tx6(0);
value = RSI(Period);
If CrossUP(value, 43) or
CrossUP(value, 50) or
CrossUP(value, 55) or
CrossUP(value, 60) or
CrossUP(value, 65) or
CrossUP(value, 70) or
CrossUP(value, 75) Then
{
var1 = value; //추가
if var1 > var1[1] Then
{
value1 = O;
value2 = 1;
value3 = O;
}
Else
{
value1 = c;
value2 = -1;
value3 = C;
}
}
plot1(value1,"1",iff(value2 == 1, MAGENTA,RGB(255,165,0)));
plot2(value3,"3",iff(value2 == 1, WHITE,WHITE));
2번 수식
Input : Period(10);
var : RSI1(0),RSIV(0),RSIV1(0),Direction(0);
RSIV = RSI(Period);
if RSIv > RSIv[1] Then{
Direction = 1;}
if RSIv < RSIv[1] Then
Direction = -1;
if Direction == 1 Then
plot1(RSIv,"RSI점");
Else
plot1(RSIv,"RSI점");
그림에서 1번수식에서 분홍색이면 2번수식에 점이 분홍색으로
1번수식에서 주홍색이면 2번수식에 점이 주홍색으로 수식부탁드립니다
2019-12-12
260
글번호 134318
답변완료
수식작성 부탁드리겠습니다.
매수조건 : 일봉 갭상승시 시초가에 생성되는 첫캔들(분봉/틱)의 종가로 매수진입 > 1틱 익절 5틱 손절
매도조건 : 일봉 갭하락시 시초가에 생성되는 첫캔들(분봉/틱)의 종가로 매도진입 > 1틱 익절 5틱 손절
국내선물, 해외선물 둘다 테스트 해볼 계획입니다. 썸머타임 스크립트 적용한 것과 적용하지 않은 것
같이 부탁드리겠습니다. 감사합니다
2019-12-12
152
글번호 134317