커뮤니티
예스랭귀지 Q&A
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1359
글번호 230811
답변완료
안녕하세요! 종목검색 수식부탁드립니다.
HU = shift(close,-midPeriod+25);
BU = BBandsUp(Period,D1);
CrossUp(HU,BU)
지표변수
midperiod 26
period 20
D1 2.0
입니다, 늘 노고에 감사드립니다. 추운겨울 몸건강 유의하세요:)
2024-11-21
813
글번호 185487
답변완료
답변 감사합니다. 한가지 추가로 여쭤보겠습니다
답변 주셔서 감사합니다
최근 올린 질문 내용중에서 질문2 에 대해서 추가로 여쭤보자면
그럼 ARRH 배열에는 arr 배열에서 5개 최고값들을 저장을 하고자 하는데요
(5개 최고가봉의 1차 VI 값들로 VII 라는 배열을 만든거처럼)
ARR 배열의 최종 구성은 5개 HIGH 값 - 0봉 HIGH 값 - 1봉전 5개 HIGH- 1봉전 HIGH ...
이런 순서로 만들려면 수식을 어떻게 수정하면 될까요?? 수식은 아래에 포함시켰습니다
답변주신 내용: 작성하신 내용이면 ARR은 최종 HARR값의 배열이 됩니다.
HARR은 최근 if H>L*1.11 Then 만족봉의 5개의 고가 중 최고가 이어야 하는데
FoR cnt = 99 downto 1
{
ARR[CNT] = ARR[CNT-1];
}
ARR[0]=HARR[0];
위 내용에 의해 ARR은 조건만족시 마다 HARR을 저장하는 배열이 되고
새로운 조건이 만족하면 해당봉의 고가와 과거 4개의 HARR 중 큰값이 HARR값이 됩니다.
즉 위 내용에 의해 ARR에 초기에 저장하는 내용이 의미가 없게 됩니다.
VAR : P1(0),SUM1(0),ARRMA(0);
var : m1(0),m2(0),T(0),HH(0),HH1(0),LL(0),CNT(0),HARR(0),hvi(0);
VAR:TLUP(0);
ARRAY : ARR[100](0),VII[100](0),ARRV[100](0),ARRH [100](0);
if H>L*1.11 Then
{
TLUP=TL_NEW(sDatE,sTimE,H,sDatE,sTimE,99999);
TL_SetColoR(TLUP,CyaN);
TL_SetSizE(TLUP,1);
for cnt = 99 downto 1
{
ARR[CNT] = ARR[CNT-1];
VII[CNT] = VII[CNT-1];
ARRV[CNT] = ARRV[CNT-1];
ARRH[CNT]= ARRH[CNT-1];
}
ARR[0] = H;
VII[0] = DayOpen*1.10;
if ARR[4] > 0 Then
{
HARR = 0;
HVI = 0;
For cnt = 0 to 4
{
if HARR == 0 or (HARR > 0 and ARR[cnt] > HARR) Then
{
HARR = ARR[cnt];
HVI = VII[cnt];
}
}
if HVI > 0 AND HARR>0 Then
{
ARRV[0] = HVI;
ARRH[0]=HARR;
}
}
FoR cnt = 99 downto 1
{
ARR[CNT] = ARR[CNT-1];
}
ARR[0]=HARR[0];
}
2024-11-21
659
글번호 185486
답변완료
문의드립니다.
안녕하세요
수식 하나 부탁드리겠습니다.
1 = ma5 > ma60 and ma60 > ma20 and open > ma20
2 = ma5 > ma20 and ma20 > ma60 and open > ma60
3 = ma5 < ma20 and ma20 < ma60 and open < ma60
1 조건 만족시 첫번째 신호에 현재 0계약 이라면 1계약 매수진입
2 조건 만족시 현재 1계약 진입중 이라면 1계약 추가매수진입(총2)
2 조건 만족시 현재 0계약 이라면 2계약 매수진입(총2)
진입식좀 부탁드리겠습니다.
청산은 각각 진입 후 50틱 익절이며
3번 조건 만족시 남은수량 전부 청산으로 부탁드리겠습니다.
2024-11-21
728
글번호 185483
답변완료
볼린저밴드 이탈
주가가 볼린저밴드 선을 터치하거나 이탈하면 최초만 세로선.
계속 이탈하면 무표시. 들어왔다 나가면 다시표시. 감사합니다.
2024-11-21
772
글번호 185482
답변완료
안녕하세요. 수식 변환 부탁드립니다.
안녕하세요.. 지표 수식으로 변환 부탁드립니다.
A = ATR(A_period);
upT = eavg(가격 + A * ratio, 기간);
dnT = eavg(가격 - A * ratio, 기간);
CC = StochasticsSlow(sto1,sto2);
k = if(CC>=50 && dnT>dnT(1), 1, if(CC<50 && upT<upT(1), -1, 0));
ValueWhen(1, k==1 or k==-1, if(k==-1, upT, dnT))
A_period 30
기간 20
ratio 5
sto1 20
sto2 10
항상 감사드립니다.
2024-11-21
856
글번호 185481
답변완료
종목검색식 부탁드림니다.
항상 노고에 감사드림니다.
아래의 수식을 종목검색식으로 부탁드림니다.
1)수식종목
CrossUp(Diplus(Period),Diminus(period))
&& CrossUp(CCI(Period),0)
&& CrossUp(macd(shortPeriod,longPeriod),
eavg(Macd(shortPeriod,longPeriod),sigPeriod))
&& v>v(1)*배수
지표변수
Period 20
shortPeriod 5
longPeriod 12
sigPeriod 9
배수 1
2)수식종목
A=LRL(20);
B=LRL(40);
D=Valuewhen(1, Crossup(A,B),A);
A1=(highest(high,shortPeriod)+lowest(low,shortPeriod))/2;
B1=shift(C,-16);
Crossup(C,A1(16))
AND
CROSSUP(C,D)
지표변수
shortperiod 6
midperiod 17
longperiod 34
2024-11-21
959
글번호 185480
답변완료
수식 재문의드립니다.
안녕하세요.
아래 90077번글 작성자입니다.
작성해주신 수식 1번과 3번을 사용해 보았는데 생각과 다르게 표현되어 다시 문의드립니다.
제 생각으로는 지표가 봉에 겹쳐져서 보여야 할 것 같은데요.
1번식은 봉과 동떨어져서 표현이 되고
3번식은 차트 중간에 일직선으로 표현이 됩니다.
제가 차트설정을 잘못하여서 그런 것인지 도움 부탁드립니다.
항상 감사합니다.
2024-11-20
800
글번호 185478
답변완료
종목검색 수식 추가 부탁드립니다.
안녕하세요. 문의드릴게 있어서 글 남깁니다.
아래 수식으로 자동매매를 하고 있는데 가끔 너무높은 (10~15%이상) 가격에 매수가되어
시가대비 현제가가 8%이상이면 매수를 하고 싶지 않았음 해서요. 수정 부탁 드립니다.
INPUT : Period1(5),Period2(60),D1(2);
VAR : A(0),B(0),조건(False);
A=MA((C+H+L)/3,Period1) - D1*STd((C+H+L)/3,Period1);
B=MA((C+H+L)/3,Period2) - D1*STd((C+H+L)/3,Period2);
IF (A[1]<b[1] OR A<B) && CROSSUP(C,B) && C>O TheN
Find(1);
2024-11-20
720
글번호 185477
답변완료
정보내용이 실제와 일치하지 않습니다.
안녕하세요. 답변주신수식이 적용하면, 종목 정보가 일치하지 않습니다. 확인부탁드립니다.
var : Grid(0);
if Index == 0 Then
{
Grid = Grid_New(7, 6, 3,White, Gray, 1, Gray, 0);
Grid_Cell(Grid,0,0,"종목명",0,0,BLACK,Green);
Grid_Cell(Grid,1,0,"현재가",0,0,BLACK,Green);
Grid_Cell(Grid,2,0,"전일대비",0,0,BLACK,Green);
Grid_Cell(Grid,3,0,"등락율",0,0,BLACK,Green);
Grid_Cell(Grid,4,0,"거래량",0,0,BLACK,Green);
Grid_Cell(Grid,5,0,"거래대금",0,0,BLACK,Green);
Grid_Cell(Grid,0,1,SymbolName,0,0,BLACK,White);
Grid_Cell(Grid,1,1,NumToStr(c,2),0,0,BLACK,White);
Grid_Cell(Grid,2,1,NumToStr(c-DayClose(1),2),0,0,BLACK,White);
Grid_Cell(Grid,3,1,NumToStr((c-DayClose(1))/DayClose(1)*100,2),0,0,BLACK,White);
Grid_Cell(Grid,4,1,NumToStr(v,0),0,0,BLACK,White);
Grid_Cell(Grid,5,1,NumToStr(m,0),0,0,BLACK,White);
Grid_CellSetWidth(Grid,0,0,20);
Grid_CellSetWidth(Grid,1,0,15);
Grid_CellSetWidth(Grid,2,0,15);
Grid_CellSetWidth(Grid,3,0,15);
Grid_CellSetWidth(Grid,4,0,15);
Grid_CellSetWidth(Grid,5,0,20);
Grid_CellSetTextVAlign(Grid,0,0,2);
Grid_CellSetTextVAlign(Grid,1,0,2);
Grid_CellSetTextVAlign(Grid,2,0,2);
Grid_CellSetTextVAlign(Grid,3,0,2);
Grid_CellSetTextVAlign(Grid,4,0,2);
Grid_CellSetTextVAlign(Grid,5,0,2);
Grid_CellSetTextVAlign(Grid,0,1,2);
Grid_CellSetTextVAlign(Grid,1,1,2);
Grid_CellSetTextVAlign(Grid,2,1,2);
Grid_CellSetTextVAlign(Grid,3,1,2);
Grid_CellSetTextVAlign(Grid,4,1,2);
Grid_CellSetTextVAlign(Grid,5,1,2);
Grid_CellSetTextHAlign(Grid,0,0,2);
Grid_CellSetTextHAlign(Grid,1,0,2);
Grid_CellSetTextHAlign(Grid,2,0,2);
Grid_CellSetTextHAlign(Grid,3,0,2);
Grid_CellSetTextHAlign(Grid,4,0,2);
Grid_CellSetTextHAlign(Grid,5,0,2);
Grid_CellSetTextHAlign(Grid,0,1,2);
Grid_CellSetTextHAlign(Grid,1,1,2);
Grid_CellSetTextHAlign(Grid,2,1,2);
Grid_CellSetTextHAlign(Grid,3,1,2);
Grid_CellSetTextHAlign(Grid,4,1,2);
Grid_CellSetTextHAlign(Grid,5,1,2);
Grid_CellSetTextColor(Grid,1,1,IFf(C>DayClose(1),Red,IFf(C<DayClose(1),Blue,Green)));
Grid_CellSetTextColor(Grid,2,1,IFf(C>DayClose(1),Red,IFf(C<DayClose(1),Blue,Green)));
Grid_CellSetTextColor(Grid,3,1,IFf(C>DayClose(1),Red,IFf(C<DayClose(1),Blue,Green)));
}
2024-11-20
662
글번호 185476