커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
6138
글번호 230811
답변완료
식수정 75237
안녕하세요
75237에 대한식
수정부탁드립니다
매수
하이프라이스 선발생후 선돌파후 양봉발생시 매수.5분봉에서 20선위에 있을것.
매도
하이프라이스 선발생후 선하향후 음봉발생시 매도.5분봉에서 20선 아래있을것 .
수고하세요
2022-03-06
1326
글번호 156959
답변완료
시스템식 문의 드립니다.
시스템 식 작성중에 어려운 부분이 있어 글 작성합니다.
1. if condition1 == true Then
Buy("1차매수",AtMarket);
위 식에서 atmarket를 사용했을때에 투자금액을 변수로 넣고 싶습니다.
예를들어
if condition1 == true Then
Buy("상한가매수",AtStop,상한가,Floor(금액1/min(NextBarOpen,상한가)));
상한가 매수시스템식에서 floor 이후에 조건을 통해서 금액을 변수로 넣을수가
있었는데.... atmarket이나 onclose 같은 경우 (뒤에 금액이 안붙어도 되는경우)
는 투자금액을 변수로 어떻게 넣어야 할지 잘 모르겠습니다.
2. 나름 식을 작성하였는데.. 생각대로 안되는 부분이 있어 요청드립니다.
2-1 당일에는 매수만 되고 다음날에는 매도가 되어야 하는데 다음날에도 매수가 되는
경우가 있다 .어떻게 해야 하나요??
2-2 추매이후에는 매도가 안되는데 왜 안될까요 ???
3. IsEntryName("S1") == true 옆 수식에서 가장 마지막으로 들어간 매수진입명
이 맞는지요??
밑에 제가 나름 열심히 만들었는데 한번 확인 부탁드리겠습니다.
-----------------------------------------------------------------------
input :금액1(500000),상한가(36500),손절금액(300000);
input : 익절(3),익절2(1);
var : cnt(0),sum(0),mav(0),DD(0);
var : day(0),entry(False),AP(0),TT(0);
var : LL(0),RR(0),rate(0);
if Bdate != Bdate[1] Then
Condition1 = False;
if sTime > 120000 and C[0] >= DayClose(1)*1.265 Then
Condition1 = true;
if TotalTrades > TotalTrades[1] Then
entry = False;
#여기서 부터 매도하기.
if condition1 == true OR LatestExitName(1) == "4%익절" Then
Buy("상한가매수",AtStop,상한가,Floor(금액1/min(NextBarOpen,상한가)));
if condition1 == true and IsEntryName("상한가매수") == true Then
Buy("BS1(상풀)",AtLimit,상한가*0.955,Floor(금액1/min(NextBarOpen,상한가*0.955)));
if condition1 == true Then
Buy("BS1",AtLimit,Dayclose(1)*1.235,Floor(금액1/min(NextBarOpen,Dayclose(1)*1.235)));
if condition1 == true and IsEntryName("BS1") == true and sdate >= EntryDate+1 and day <=1 Then
Buy("S1",AtLimit,Dayclose(1)*1.19,Floor(금액1/min(NextBarOpen,Dayclose(1)*1.19)));
if condition1 == true and IsEntryName("BS1") == true and sTime == 150800 Then
Buy("3시10분매수(1-1)",AtMarket);
if condition1 == true and IsEntryName("3시10분매수(1-1)") == true and sTime == 151300 Then
Buy("3시15분매수(1-2)",AtMarket);
if condition1 == true and IsEntryName("3시10분매수(1-1)") == true and sTime == 151700 Then
Buy("3시19분매수(1-3)",AtMarket);
if condition1 == true and MarketPosition == 0 and sTime == 150800 Then
Buy("3시10분매수(2-1)",AtMarket);
if condition1 == true and IsEntryName("3시10분매수(2-1)") == true and sTime == 151300 Then
Buy("3시15분매수(2-2)",AtMarket);
if condition1 == true and IsEntryName("3시10분매수(2-1)") == true and sTime == 151700 Then
Buy("3시19분매수(2-3)",AtMarket);
if MarketPosition == 1 and day >=2 and DayOpen*1.04>=DayHigh Then
Buy("S1(NEXT)",AtLimit,DayHigh*0.92,Floor(금액1/min(NextBarOpen,DayHigh*0.92)));
#여기서 부터 매도하기.
if MarketPosition == 1 Then
{
if LL == 0 then
LL = L;
Else
{
if L < LL then
LL = L;
}
RR = (LL-AVGEntryPrice)/AVGEntryPrice*100;
if RR >= -0.9 Then
Rate = 익절;
if RR >= -2.9 and RR < -0.9 Then
Rate = (익절+RR);
if RR < -2.9 Then
Rate = 0.3;
ExitLong("3%익절",AtLimit,AVGEntryPrice*(1+Rate/100),"",Floor(MaxContracts*0.5));
ExitLong("4%익절",AtLimit,AVGEntryPrice*(1.01+Rate/100));
}
Else
LL = 0;
#----------------------------------------------------------------------------
# 3%, 4% 매도 청산
#----------------------------------------------------------------------------
if MarketPosition == 1 AND IsEntryName("S1") == true or IsEntryName("S1(NEXT)") == true or IsEntryName("BS1(상풀)") == true Then
{
ExitLong("0.3%익절",AtLimit,AVGEntryPrice*1.003,"",Floor(MaxContracts*0.5));
ExitLong("1%익절",AtLimit,AVGEntryPrice*1.1);
}
Else
LL = 0;
#----------------------------------------------------------------------------
# 0.3%, 1% 매도 청산
#----------------------------------------------------------------------------
if MarketPosition == 1 Then
if sdate >= EntryDate+1 and sTime == 100000 Then
{
ExitLong("다음날 10시청산");
}
#----------------------------------------------------------------------------
# 다음날 10시 청산
#----------------------------------------------------------------------------
if MarketPosition == 1 Then
ExitLong("손절",AtStop,AvgEntryPrice-손절금액/CurrentContracts);
#----------------------------------------------------------------------------
# 손절
2022-03-06
1376
글번호 156958
답변완료
수식 질문드립니다.
수식 합치는거좀 부 탁드립니다.
Option.GetATMCallRecent(n)
Option.GetATMPutRecent(n)
요걸 수정하기 위함입니다.
1. 홈페이지 스팟 메뉴얼에 있는식입니다.
var Start;
var B1CallCode;
var B1PutCode;
var S1CallCode;
var S1PutCode;
function Main_OnStart()
{
Main.MessageLog("시작");
Start = 0;
}
function C1_OnRiseSignal(Signal)
{
Main.MessageLog("신호완성/"+Signal.signalKind);
if (Signal.signalKind == 1 )
{
Start = 1;
B1CallCode = Option.GetATMCallRecent(n);
var B1CallPrice = Option.GetAskByCode(B1CallCode,2);
A1.OrderBuy(B1CallCode, Vol1, B1CallPrice, 0);
Main.MessageLog("콜매수");
}
if (Start == 1 && Signal.signalKind == 2 )
{
var B1xCallPrice = Option.GetBidByCode(B1CallCode, 2);
A1.OrderSell(B1CallCode, Vol1, B1xCallPrice, 0);
Main.MessageLog("콜매수청산");
}
if (Signal.signalKind == 3 )
{
Start = 1;
S1PutCode = Option.GetATMPutRecent(n);
var S1PutPrice = Option.GetAskByCode(S1PutCode,2);
A1.OrderBuy(S1PutCode, Vol1, S1PutPrice, 0);
Main.MessageLog("풋매수");
}
if (Start == 1 && Signal.signalKind == 4 )
{
var S1xPutPrice = Option.GetBidByCode(S1PutCode, 2);
A1.OrderSell(S1PutCode, Vol1, S1xPutPrice, 0);
Main.MessageLog("합성선물매도청산");
}
}
2.1번의 식에다가 아래 easy language 식을 넣고 싶습니다.
var : c2(0,Data2);
var : n(0);
c2 = Data2(c);
if c2>0 Then n=ceiling(c2*7/2.5);
if c2>1 Then n=ceiling(c2*5/2.5);
if c2>2 Then n=ceiling(c2*4/2.5);
if c2>3 Then n=ceiling(c2*3/2.5);
if c2>7 Then n=ceiling(c2*2.5/2.5);
#Plot1(n);
3. 여기서 문제가 메뉴얼에는 data2 부터 쓰라고 나와있는데
사진처럼 data1 써도 상관없는거죠? data1에서 datamanager 불러지던데요.
"888"은 data manager의 data 입니다.
감사합니다.
2022-03-06
1887
글번호 156957
답변완료
지표 질문입니다
틱 차트에서
D-2일 고가와 D-3일 고가를 연결하는 선을 그린다
D-1일 고가와 D-2일 고가를 연결하는 선을 그린다
D-1일 고가와 당일 고가를 연결하는 선을 그린다
D-2일 저가와 D-3일 저가를 연결하는 선을 그린다
D-1일 저가와 D-2일 저가를 연결하는 선을 그린다
D-1일 저가와 당일 저가를 연결하는 선을 그린다
감사합니다
2022-03-06
1298
글번호 156956
답변완료
시스템 수식문의(전일가격참조)
수고가 많으십니다.
아래와 같은 수식을 작성하고자 합니다.
매매조건(10분봉 기준)
전일 09:00~09:10 이 양봉이면
금일 09:00~09:10 entry long
전일 09:00~09:10 이 음봉이면
금일 09:00~09:10 entry sell
당일 재진입금지
2022-03-05
1394
글번호 156955
답변완료
문의드립니다.
10일전 첫 1분봉의 거래대금이
50억 이상인 종목들을 검색하고자 합니다.
기준봉 및 검색에 필요한 최소 기간에 대한
입력 숫자도 언급부탁드립니다.
감사합니다.
2022-03-06
1136
글번호 156954
답변완료
문의드립니다.
스토어캐스틱 퍼스트 59에서 65사이에 양봉캔들발생 매도.
캔들종가가 65 위의 있어야 하고 매수한 그 캔들의 고가보다 높게 봉완성되면 손절청산.
익절200틱.
수고하세요.
2022-03-06
1098
글번호 156953
답변완료
문의드립니다.
스토어캐스틱 퍼스트 35에서 41사이에 음봉캔들 발생 매수.
캔들종가가 35보다 아래의 있고 매수한 그 캔들의 저가보다 낮게 봉완성되면 손절청산.
익절200틱.
부탁드립니다. 수고하세요.
2022-03-06
1222
글번호 156952
답변완료
수식 문의드립니다.
1분봉 스토캐(5,3,3) 골든크로스 및 5분봉 스토캐 K>D 일때 매수
1분봉차트에서 스토캐 및 5분봉 스토캐 값을 구해서 전략에 사용하려고 합니다.
항상 도움주셔서 감사합니다.
2022-03-04
1158
글번호 156951