커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
3603
글번호 230811
답변완료
신호가 발생 안하는 이유?
안녕하세요?
kospi200 선물입니다
Data1: 45분봉 Data2: 일봉입니다.
input : BPeriod(20),BDv(2.04);
if Crossup(Data2(C), Data2(BollBandUp(BPeriod,BDv))) and Data1(C) >= Data2(C) then Buy("B1",AtMarket,def,TdQ);
11월 10일에 위로직대로면 매수 신호가 발생해야 하는데 안하는 이유가 먼가요?
11월9일에 볼린저 밴드 상단돌파후 11월 10일 매수해야 하는데 왜안하죠?
2020-11-11
688
글번호 143814
답변완료
분할매도 관련 시스템식 요청드립니다.
안녕하세요 수고가 많으십니다.
분할매도 관련된 시스템식 요청드립니다.
만약에 100주가 있다면
1% 10주, 2% 10주, 3% 10주, 4% 10주, 5% 10주, 6% 10주, 7% 10주, 8% 10주, 9% 10주
(10주는 남아있음)
이렇게 동일하게 주식수가 분할매도 되는 식을 요청드립니다.
몇가지 질문이 있는데
1. Bdate == Bdate[1] 의 수식과 Sdate == Sdate[1] 의 차이점이 몬지 궁금합니다
2. BDATE == BDATE[1] 의 뜻은 몬가요??? BDATE는 영업일 시작일 이고 BDATE[1] 전 영업일
시작일 아닌가요? == 는 뜻은 같다라는 뜻인데?? 이해가 잘 안갑니다.ㅜ.ㅜ
2020-11-11
697
글번호 143808
답변완료
검색식 문의드립니다.
조건만족시 검색되게해주세요
모든 수치는 기본수치로하고 제가 변경할수 있게 해주시면 감사하겠습니다.
1. 볼린져밴드 중간선과상한선 (범위내)에 있는것중에
연속 2~4봉 음봉이 나온것을 찾고싶습니다.
2. 볼린져밴드 중간선과 상한선 (범위내)에 엔벨로프와 볼린져밴드 골든크리스후
엔벨로프(기준선)에 3%눌리는 종목을 찾고 싶습니다. 당연히 눌리는 종목이니
음봉일겁니다. or 음봉나오면 검색되게 해주시면 감사하겠습니다.
오늘도 좋은하루되세요!~
2020-11-11
607
글번호 143807
답변완료
재문의드립니다
69862번 1번항재문의 드립니다 현재파동고점과저점에 수치가 나오는데 제가원하는것이 아닙니다~~상승추세선 시작점수치와 끈나는 부분수치값이 나오게
하락추세선 시작점수치와 끈나는 부분수치값이 나오게현재가처럼마지막값이나오게 다시한번수정부탁드립니다~~`
2020-11-11
652
글번호 143805
답변완료
문의
buy식은 아래처럼 하면 되는지요?
var : sum(0,Data2),do(0,Data2),dh(0,Data2),dh1(0,Data2);
sum = Data2(c)+data3(c);
if data2(bdate != Bdate[1]) Then
{
do = sum;
dh = sum;
dh1 = dh[1];
}
if sum > dh Then
dh = sum;
if stime >= 100000 and sum <= do+2.00 and sum >= do+1.00 then
buy("b1");
if stime >= 100000 and sum <= dh1+2.00 and sum >= dh1+1.00 then
buy("b2");
***********************************************************************************
안녕하세요
예스스탁입니다.
var : sum(0,Data2),do(0,Data2),dl(0,Data2),dl1(0,Data2);
sum = Data2(c)+data3(c);
if data2(bdate != Bdate[1]) Then
{
do = sum;
dl = sum;
dl1 = dl[1];
}
if sum < dl Then
dl = sum;
if stime >= 100000 and sum <= do-1.00 and sum >= do-2.00 then
sell("s1");
if stime >= 100000 and sum <= dl1-1.00 and sum >= dl1-2.00 then
sell("s2");
즐거운 하루되세요
> 목마와숙녀 님이 쓴 글입니다.
> 제목 : 문의
> data1 선물
data2 콜연결atm0
data3 풋연결atm0
양합(data2+data3)
생성된 양합으로 진입합니다.
데이트레이딩
1)
if stime >= 100000 and 금일 양합 open - 금일 양합(1.00 ~ 2.00) then
sell();
10시 부터
금일 양합이 090000기준 양합 시가 - (1.00 ~ 2.00)이면 sell
2)
if stime >= 100000 and 전일 양합 저점 - 금일 양합(1.00 ~ 2.00) then
sell();
10시 부터
금일 양합이 전일 양합 저점 - (1.00 ~ 2.00) 이면 sell
수식 부탁드립니다.
2020-11-11
560
글번호 143801
새론시작 님에 의해서 삭제되었습니다.
2020-11-11
11
글번호 143799
답변완료
아래 수식의 잘못 표기된곳은요?
Input : Period(1);
var1 = Plot1(ma((h+l)/2,Period), "이동평균");
if var1 > var1[1] Then
Plot1(var1,"지표",red);
Else
Plot1(var1,"지표",blue);
2020-11-11
360
글번호 143798
답변완료
수식의뢰드립니다.
업무에 노고가 많으십니다.
과거 20일부터 그 이전 과거10일까지의 고가중 최고가를 구하고 싶습니다.(일봉기준)
ex) 오늘이 11월 11일/10월 10일 ~ 10월 20일의 고가 중 최고가
현재부터 과거 10일까지의 고가를 구하는 수식은 highest(H, 10)으로 가능한걸로 알고 있는데 위의 수식은 어떻게 되는지 궁금합니다.
2020-11-11
437
글번호 143797
답변완료
수식의뢰 드립니다!
안녕하세요!
일목의 파동 목표가를 구하는 수식을 만들어 보다가 너무 어려워 도움을 부탁드립니다!
이해를 돕고져 첨부해 드리는 이미지와 수식을 기준으로 목표가를 나타내고 싶습니다.
(조건)
A = 이전 파동 최고점
B = 이전 파동 최저점
C = 현재 파동 최고점
D = 현재 파동 최고점 이후 눌림이 최저점
(산출식)
E = 2*C-B
V = 2*C-D
N = C-B+D
NT = 2*D-B
VT = 2*A-B
--------------------------------
위의 산출식이 안되면 아래식으로도 해주셔도 됩니다
A = 파동전 최저점(파동의 시작점)
B = 파동후 최고점
C = B이후의 눌림 목 최저점
V = 2B - C
N = C+B-A
E = 2B-A
NT = 2C-A
부탁드려요!
----------------------------------------
항상 노고에 감사드립니다!
input:length(4),종가사용여부(0),파동선두께(1),수치표시(1);
Var:j(0),jj(0),HH(0),LL(0),최종고가(0),최종저가(0),최종꼭지점(""),처리구분(""),
TL1(0),Text1(0),tl2(0),tl3(0),tl4(0),tl5(0),T(0);
Array:고[10,4](0),저[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime
#==========================================#
HH = IFF(종가사용여부==1,C,H);
LL = IFF(종가사용여부==1,C,L);
If Index == 0 Then
{
고[1,1] = HH;
저[1,1] = LL;
}
Condition1 = Highest(HH,length) == HH and 최종고가 <> HH;
Condition2 = Lowest (LL,length) == LL and 최종저가 <> LL;
처리구분 = "";
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
{
T = 1;
최종고가 = HH; // 신규고점을 체크하기 위해 저장
If 최종꼭지점 == "저점" Then
{
For j = 10 DownTo 2
{
For jj = 1 To 4
{
고[j,jj] = 고[j-1,jj];
}
}
고[1,1] = HH;
고[1,2] = Index;
고[1,3] = sDate;
고[1,4] = sTime;
# 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,BLACK);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,yellow);
}
Else If 고[1,1] < HH Then // 1번 고점보다 높은 고가 출현
{
고[1,1] = HH;
고[1,2] = Index;
고[1,3] = sDate;
고[1,4] = sTime;
# 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
{
T = -1;
최종저가 = LL;
If 최종꼭지점 == "고점" then
{
For j = 10 DownTo 2
{
For jj = 1 To 4
{
저[j,jj] = 저[j-1,jj];
}
}
저[1,1] = LL;
저[1,2] = Index;
저[1,3] = sDate;
저[1,4] = sTime;
# 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,BLACK);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,blue);
}
Else If 저[1,1] > LL then
{
저[1,1] = LL;
저[1,2] = Index;
저[1,3] = sDate;
저[1,4] = sTime;
# 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 T == -1 and T[1] != -1 Then{
TL2 = TL_New(고[2,3],고[2,4],고[2,1],sdate,stime,고[2,1]);
TL_Delete(TL3);
TL3 = TL_New(고[1,3],고[1,4],고[1,1],sdate,stime,고[1,1]);
TL_SetExtRight(TL3,true);
TL_SetSize(TL2,파동선두께);
TL_SetColor(TL2,rgb(126,126,126));
TL_SetSize(TL3,파동선두께);
TL_SetColor(TL3,rgb(126,126,126));
}
if T == 1 and T[1] != 1 Then{
TL4= TL_New(저[2,3],저[2,4],저[2,1],sdate,stime,저[2,1]);
TL_Delete(TL5);
TL5= TL_New(저[1,3],저[1,4],저[1,1],sdate,stime,저[1,1]);
TL_SetExtRight(TL5,true);
TL_SetSize(TL4,파동선두께);
TL_SetColor(TL4,rgb(128,128,128));
TL_SetSize(TL5,파동선두께);
TL_SetColor(TL5,rgb(128,128,128));
}
2020-11-12
572
글번호 143796