커뮤니티
예스랭귀지 Q&A
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1359
글번호 230811
답변완료
추가 질의
18일날 번호 90038번의 질의에 대한 답변 감사합니다..
답변중에 매도 매수 화살표 넣는 곳이 있는데
키보드에는 없는데...(첨부자료 참고)
초보라서 넣는 방법을 자세히 알려 주시면 감사하겠습니다..
(그리고 에스랭기지 에서 만들때 지표,검색,참조,시스템 등이 있는데..지표에서 만들면 되는거져?)
2024-11-19
695
글번호 185440
답변완료
여쭤 봅니다
안녕하세요
챠트 표시를 봉챠트에서 종가점챠트로 변경해서 보고자 합니다.
여기서 종가점챠트가 삼각가중 20선위에 있을때는 종가점이 레드, 삼각가중 20선
아래에 있을때 종가점이 블루로 표시가 가능한지 여쭤보고자 합니다.
2024-11-19
680
글번호 185439
답변완료
2개의 지표값을 활용한 새로운 지표 수식 문의드립니다.
기존의 2개(A,B)의 지표를 활용하여 새로운 C지표를 만들려고 합니다.
"A지표 + B지표 = 새로운 지표(C)"
지표 수식을 부탁드립니다.
(1) A지표 수식은 다음과 같습니다.
var : C2(0,Data2),H2(0,Data2),L2(0,Data2);
C2 = Data2(-C);
if Data2(Bdate != Bdate[1]) Then
{
h2 = C2;
l2 = C2;
}
if C2 > h2 Then
h2 = C2;
if C2 < L2 Then
L2 = C2;
Plot1(C2,"C2",IFf(C2>0,Red,Blue));
Plot2(H2,"당일최고",Blue);
Plot3(L2,"당일최저",Red);
PlotBaseLine1(0,"기준선");
(2) B지표 수식은 다음과 같습니다.
var : C3(0,Data3),H3(0,Data3),L3(0,Data3);
C3 = Data3(C);
if Data3(Bdate != Bdate[1]) Then
{
h3 = C3;
l3 = C3;
}
if C3 > h3 Then
h3 = C3;
if C3 < L3 Then
L3 = C3;
Plot1(C3,"C3",IFf(C3>0,Red,Blue));
Plot2(H3,"당일최고",Blue);
Plot3(L3,"당일최저",Red);
PlotBaseLine1(0,"기준선");
(3) C지표는 위의 [A지표 값 + B지표 값]으로 계산된 새로운 지표를 만들고자 합니다.
예를 들어,
A지표값이 +1,000이고, B 지표값이 +1,000면, C지표는 +2,000
A지표값이 +1,000이고, B 지표값이 -1,000면, C지표는 0
A지표값이 -1,000이고, B 지표값이 -1,000면, C지표는 -2,000
C지표의 수식을 부탁드립니다. 그리고, A,B지표처럼 당일 고가, 저가 라인이 표시되도록 부탁드립니다.
2024-11-19
671
글번호 185438
답변완료
수식및 표시방법좀 부탁드립니다.
매번 감사합니다.
아래 3가지 부분 부탁드립니다.
1.수식을 시스템 파일로 할때, 사진처럼 차트쉐어에서 전체공개시 사람들이 편의에 맞게 조
정해서 쓰게 하고자 합니다. 그림1 표시 나오는 수식?방법? 좀 알려주세요
2. 차트 하단에 종목 정보좀 나타나게하는 수식?방법? 좀 알려주세요(그림2 참조)
3. 마지막으로 시스템 파일 아래 수식은 rsi 조건만 인데, 만약 smi(Squeeze Momentum Indicator)를 조합해서 한다고 할때 buy 와 exitlong 수식에 2가지 조건(rsi, smi)표시하는 수식좀 만들어주세요
1.rsi
input : P(14);
var1 = RSI(P);
if CrossUp(var1,30) Then
Buy("매수");
if CrossDown(var1,70) Then
exitlong("매도");
2.smi(Squeeze Momentum Indicator)
input : length(20);
input : mult(2.0);
input : lengthKC(20);
input : multKC(1.5);
input : useTrueRange(true);#1:TrueRange 0:고저폭
var : source(0),basis(0),dev(0),upperbb(0),lowerbb(0);
var : mav(0),r(0),rangema(0),upperKC(0),lowerKC(0);
var : sqzOn(False),sqzOff(False),noSqz(False),val(0),bcolor(0),scolor(0);
// Calculate BB
source = close;
basis = ma(source, length);
dev = multKC * std(source, length);
upperBB = basis + dev;
lowerBB = basis - dev;
// Calculate KC
mav = ma(source, lengthKC);
r = iff(useTrueRange == 1 , TrueRange , (high - low));
rangema = ma(r, lengthKC);
upperKC = mav + rangema * multKC;
lowerKC = mav - rangema * multKC;
sqzOn = (lowerBB > lowerKC) and (upperBB < upperKC);
sqzOff = (lowerBB < lowerKC) and (upperBB > upperKC);
noSqz = (sqzOn == false) and (sqzOff == false);
val = LRL(source - avg(avg(highest(high, lengthKC), lowest(low, lengthKC)),ma(close,lengthKC)), lengthKC);
bcolor = iff( val > 0,
iff( val > iff(IsNan(val[1]),0,val[1]), lime, green),
iff( val < iff(IsNan(val[1]),0,val[1]), red, maroon));
scolor = iff(noSqz ,blue ,IFf( sqzOn , black , gray ));
if bcolor == lime and scolor == Gray Then
Buy("b");
if bcolor == green and scolor == black Then
ExitLong("bx");
2024-11-19
854
글번호 185437
김승빈 님에 의해서 삭제되었습니다.
2024-11-19
1
글번호 185436
답변완료
문의드립니다
틱차트에서
현재봉기준으로 지나간 최근 30초 동안의
누적거래대금 지표
예)
90031 ~ 90001 사이의 누적거래대금
90032 ~ 90002 사이의 누적거래대금
90033 ~ 90003 사이의 누적거래대금
...
감사합니다
2024-11-19
630
글번호 185435
답변완료
문의드립니다
안녕하세요 항상고맙습니다
다름이 아니라 시간에 따라 옵션진입조건을 다르게 하고싶은데 어떻게 해야 될지 몰라서 문의드립니다
일단 변수에 시간을 선언했구요
var firstEntryStartTime = 90000; // 9시 진입 시작 시간
var firstEntryEndTime = 93000; // 9시 30분까지 진입 가능 시간
var stopTime = 93000; // 9시 30분 이후 포지션 스톱 시간
var secondEntryStartTime = 110000; // 11시 진입 시작 시간
var secondEntryEndTime = 130000; // 1시까지 진입 가능 시간
이렇게하고나서
function Main_OnU*dateMarket(sItemCode, lU*dateID)
{
var d = new Date();
var HHMMSS = d.getHours() * 10000 + d.getMinutes() * 100 + d.getSeconds();
if (dayOfWeek == "수")
{
// // 첫 번째 진입 조건: 9시 ~ 9시 30분 사이에만 진입 허용
if (HHMMSS >= firstEntryStartTime && HHMMSS <= firstEntryEndTime)
{
옵션진입체크();
}
// 두 번째 진입 조건: 11시 ~ 1시 사이에만 진입 허용
else if (HHMMSS >= secondEntryStartTime && HHMMSS <= secondEntryEndTime)
{
옵션진입체크();
}
// 9시 30분 이후 첫 번째 진입 종료
else if (HHMMSS > stopTime && T != 0)
{
Main.MessageList("9시 30분 이후 포지션 스톱");
Main_OnStop(); // 포지션 스톱 처리
이렇게 매수조건에 따로 함수로 불러오는게 맞는건지
아니면 매수진입식에
// 콜 매수 조건
if (MarketData1.current >= MarketData1.open && 외인순매수 > 500 && HHMMSS >= firstEntryStartTime && HHMMSS <= firstEntryEndTime ) {
CallCode = "";
CallPrice = 0;
for (var i = -Option1.lowersATM; i <= Option1.uppersATM; i++) {
var optionPrice = Option1.GetCurrent(0, i);
if (optionPrice >= 0.05 && optionPrice <= 0.29 && (CallPrice === 0 || optionPrice < CallPrice)) {
CallPrice = optionPrice;
CallCode = Option1.GetATMCallRecent(i);
}
}
if (CallPrice > 0) {
CBEID = Account1.OrderBuy(CallCode, 옵션수량, Option1.GetCurrent(CallCode), 0);
Main.MessageList("콜 옵션 매수 진입1");
BuyPrice = CallPrice;
if (T >= 0 && 진입 == true) {
// 콜 옵션 매수 조건: 현재가가 시가 기준 위 10틱 이내에서 캔들의 저가가 존재할 때
if (MarketData1.current > MarketData1.open
&& MarketData1.current <= MarketData1.open + MarketData1.GetTickSize() * 10
&& 외인순매수 > 500
&& HHMMSS >= secondEntryStartTime
&& HHMMSS <= secondEntryEndTime) {
각각 이렇게 넣는게 맞는건지 매수진입조건에 넣으면 저위에 따로 함수부른건 필요없을것 같은데 그럼 지워도 되는건지 여쭤봅니다
2024-11-19
611
글번호 185433
유경완 님에 의해서 삭제되었습니다.
2024-11-19
53
글번호 185432
답변완료
가로 수평선의 연장(과거 기록도 보존)
1-1 위 위 사진은 붉은 기둥위에 해당 캔들에 붉은색 박스만 생겼음(과거에) 이 박스안에 캔들들의 고가와 저가 선을 수평으로 다음 붉은 캔들이 있을 때까지 연장해달라는 의미임
1-2 바로 위 사진은 현재 진행형 수평선으로 가장 최신 수평선은 이렇게 나타난다(그런데 과거는 단순히 박스형태로만 나타난다)
2-1. 현재이 수평선만 표기되어 있고 과거에서는 붉은 기둥 부분의 캔들들만 박스처럼 처리 되었는데 과거도 수평선 2개가 유지 되어 새로운 붉은 기둥캔들이 생겨 대체 될 때까지 유지 되도록 부탁합니다.
2-2. 그리고 수평선의 색깔 및 굵기 그리고 두 고저 수평선 사이에 넣을 색도 고를 수 있게 변수로 처리해주시면 감사합니다.
아래는 관련 수식입니다.
var : box(0),TL1(0),TL2(0);
Input: ADXPeriod(14), ADXThreshold(10); // 사용자 입력 변수
Condition1 = ADX(ADXPeriod) > ADXThreshold;
if Condition1 == False Then
{
if Condition1[1] == true Then
{
var1 = sDate;
var2 = sTime;
var3 = h;
var4 = l;
var5 = 0;
box = Box_New(sDate,sTime,var3,NextBarSdate,NextBarStime,var4);
Box_SetColor(box,Cyan);
Box_SetFill(box,true);
TL_Delete(TL1);
TL_Delete(TL2);
TL1 = TL_New(sDate,sTime,var3,NextBarSdate,NextBarStime,var3);
TL2 = TL_New(sDate,sTime,var4,NextBarSdate,NextBarStime,var4);
TL_SetColor(TL1,Cyan);
TL_SetColor(TL2,Cyan);
TL_SetExtRight(TL1,true);
TL_SetExtRight(TL2,true);
}
Else
{
if var1 > 0 Then
var5 = var5+1;
if var3 > 0 and h > var3 Then
var3 = h;
if var4 > 0 and l < var4 Then
var4 = l;
Box_SetBegin(box,var1,var2,var3);
Box_SetEnd(box,sDate,sTime,var4);
TL_SetBegin(TL1,var1,var2,var3);
TL_SetBegin(TL2,var1,var2,var4);
TL_SetEnd(TL1,sDate,sTime,var3);
TL_SetEnd(TL2,sDate,sTime,var4);
}
}
Else
var5 = 0;
Plot1(var5,"봉수",Red);
2024-11-19
542
글번호 185431