커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4398
글번호 230811
답변완료
수식 문의
안녕하세요?
서로 비슷한 시스템 2개의 수식을 부탁드립니다.
감사합니다.
2017-04-25
190
글번호 109124
답변완료
일봉에서 20일선 위에서만 시스템 가동
일봉에서 ~
20일선 위에서만 시스템가동
수식 부닥드려요.
2017-04-24
190
글번호 109123
답변완료
부탁드립니다.
20이평을 돌파후 바로 다음 봉이 양봉이면 매수
20이평을 붕괴후 바로 다음 봉이 음봉이면 매도 하는
시스템식 부탁드립니다..
2017-04-24
184
글번호 109122
답변완료
수식부탁드립니다
체결강도인데 키움에 정보를 찾아보니 이걸 구현하고싶습니다
체결강도는 종목별로 하루 중 매수체결, 매도체결수량을 합산하여 매수체결 나누기 매도체결 * 100 으로 계산합니다.
체결강도에서의 매수체결, 매도체결의 의미는 다음과 같습니다.
직전 체결가와 비교하여 크면 매수체결, 작으면 매도체결로 합니다.
직전체결가와 현재의 체결가가 같으면 직전의 방향성을 유지합니다.
여기서 방향성이란 직전의 체결이 매수체결이면 이번체결도 매수체결, 직전의 체결이 매도체결이면 이번체결도 매도체결로 계산을 합니다.
이 체결량들을 하루 중 종목별로 매수 매도 각각 합산하여 체결강도를 구합니다. 매수체결량이 매도체결량보다 많으면 100%가 넘는 값이 되고 반대이면 100% 미만의 값이 됩니다.
2017-04-24
235
글번호 109121
답변완료
시스템 수식 작성 부탁드립니다.
저점대비 3% 반등시 매수
고점대비 3% 하락시 매도
2017-04-24
174
글번호 109120
답변완료
수식문의
아래 var1값과, var2값을 해당 봉에 숫자(텍스트)로 나타나게 할 수 있나요?
감사합니다
> 예스스탁 님이 쓴 글입니다.
> 제목 : Re : 수식문의
> 안녕하세요
예스스탁입니다.
Input : short(12),long(26),sig(9);
Var : MACDv(0),MACDS(0),T(0),Hv(0),Lv(0);
MACDv = MACD(short, long);
MACDs = ema(MACDv,sig);
if crossup(MACDV,MACDS) Then{
T = 1;
Hv = H;
var1 = Lv;
}
if CrossDown(MACDV,MACDS) Then{
T = -1;
Lv = L;
var2 = Hv;
}
if T == 1 Then{
if H > Hv Then
Hv = H;
}
if T == -1 then{
if L < Lv Then
Lv = L;
}
plot1(var1);
plot2(var2);
2017-04-24
181
글번호 109119
답변완료
수식검증 부탁합니다.
수식작성이 잘 안되서 부탁드립니다.
Input : Period(1);
var : kk(0,data2),aa(0,data2),diff(0,data2);
<< 중간에 수식이 있습니다.>>
input : Nd(60);
var : SSd(0),TSd(0),secondd(0),hsbb(0);
var : countd(0),cntd(0);
if Bdate != Bdate[1] Then{
var5 = TimeToMinutes(stime)*60;
var6 = FracPortion(stime/100)*100;
SSd = var5+var6;
Secondd = 0;
hsbb = 0;
}
if Bdate == Bdate[1] Then{
value3 = TimeToMinutes(stime)*60;
value4 = FracPortion(stime/100)*100;
TSd = value3+value4;
Secondd = TSd-SSd;
hsbb = ((Secondd-Secondd[1])-BarInterval)/BarInterval;
}
countd = 0;
for cntd = 0 to Nd-1{
if sdate[cntd] == sdate then
countd = countd + hsbb[cntd];
}
var7 = Highest(h,70);
var8 = Lowest(L, 70);
var9 = Lowest(L, 30);
Condition1 = countd >= 12
;
Condition2 = countd >= 12 and CountIF(var7 > var7[1], 20) < 1 and CountIF(var8 < var8[1], 20) < 1
and CountIF(hsbb >= 1 , 10) >= 1 ;
if Condition2 == True and Condition2[1] == False
Then
Sell("매도1", OnClose);
if BarsSinceEntry > 30
Then
ExitShort("정리1");
위와같이 수식을 작성 하였는데요..
위에 있는 수식은 오류없이 원하는 결과가 나옵니다.
그런데 nd(60) 부터 시작하는.. 아래의 수식에서 계속 오류가 발생하네요..
그 위의 수식은 건드리지 않고 아래 수식에 변화를 주어서 원하는 결과를 얻고 싶습니다.
잘라내기를 하면서 검증해보니까..
var : kk(0,data2),aa(0,data2),diff(0,data2); 이 라인때문에 오류가 발생합니다.
여기를 잘라내고 검증하면 원하는 결과가 그대로 나오는데 사실 아래것을 추가하기 위해서 없앨수가 없거든요..
또, data2가 들어간다고 해서 아래 수식에서 딱히 영향을 미칠만한 것도 제 눈에는 안보이네요.. 어디가 잘못된 것이지 조언 부탁합니다.
감사 합니다.
2017-04-24
179
글번호 109118
답변완료
급등후 매수 전략
안녕하세요!!
첨부파일을 참고하셔서
시가가 20일 이평선(파란선)에서 갭상승 급등 또는 급등 할 때 매수신호 발생 코딩
1) 첨부 그림에서 BC매수 지점에 매수하는 것이 아니라 충분히 하락하여
20이평선에 도달하여 반등할 때 매수하는 경우
2) 반대로 BC매수 하루전의 장대 양봉에서 하락하지 않고 바로 계속 상승할 경우에도
매수 신호
3) 세번째는 장대 양봉의 종가를 기준으로 2% ~ 3% 등락하며 며칠 횡보하다가 상승하는 경우
4) 매도는 최고점
시스템이 1), 2), 3)의 중에서 판단하여서 각 경우에 해당 매수 신호를 주고 난뒤
4)의 조건에서 매도를 가능하게 하는 시스템 코딩을 제공해 주시면 감사하겠습니다
항상 감사드립니다.
2017-04-25
234
글번호 109113
답변완료
종목검색 기초적인 문의드립니다.
특정종목코드가 특정가격 보다 아래로 내려가면 검색되도록 하고 싶습니다.
아래 코드처럼 하니 작동이 안되네요. 수정 부탁드립니다.
If StrToNum(SymbolCode()) == 000030 And Close <= 14650 Then Value1 = 1;
If StrToNum(SymbolCode()) == 000250 And Close <= 14500 Then Value1 = 1;
If StrToNum(SymbolCode()) == 000660 And Close <= 52500 Then Value1 = 1;
If StrToNum(SymbolCode()) == 000720 And Close <= 49650 Then Value1 = 1;
If StrToNum(SymbolCode()) == 001070 And Close <= 102000 Then Value1 = 1;
If StrToNum(SymbolCode()) == 001340 And Close <= 2680 Then Value1 = 1;
If StrToNum(SymbolCode()) == 001515 And Close <= 3175 Then Value1 = 1;
If StrToNum(SymbolCode()) == 001740 And Close <= 7800 Then Value1 = 1;
If StrToNum(SymbolCode()) == 001840 And Close <= 6220 Then Value1 = 1;
If StrToNum(SymbolCode()) == 002870 And Close <= 14700 Then Value1 = 1;
If StrToNum(SymbolCode()) == 003160 And Close <= 6120 Then Value1 = 1;
If StrToNum(SymbolCode()) == 003230 And Close <= 56500 Then Value1 = 1;
If StrToNum(SymbolCode()) == 003300 And Close <= 113000 Then Value1 = 1;
If StrToNum(SymbolCode()) == 003670 And Close <= 14600 Then Value1 = 1;
If StrToNum(SymbolCode()) == 003920 And Close <= 876000 Then Value1 = 1;
If StrToNum(SymbolCode()) == 004100 And Close <= 2760 Then Value1 = 1;
If StrToNum(SymbolCode()) == 005450 And Close <= 8310 Then Value1 = 1;
If StrToNum(SymbolCode()) == 005725 And Close <= 5990 Then Value1 = 1;
If StrToNum(SymbolCode()) == 005740 And Close <= 30500 Then Value1 = 1;
If StrToNum(SymbolCode()) == 005745 And Close <= 21750 Then Value1 = 1;
If StrToNum(SymbolCode()) == 005930 And Close <= 2052000 Then Value1 = 1;
If StrToNum(SymbolCode()) == 005935 And Close <= 1587000 Then Value1 = 1;
If StrToNum(SymbolCode()) == 005940 And Close <= 12550 Then Value1 = 1;
If StrToNum(SymbolCode()) == 006400 And Close <= 137500 Then Value1 = 1;
If StrToNum(SymbolCode()) == 007330 And Close <= 7180 Then Value1 = 1;
If StrToNum(SymbolCode()) == 007700 And Close <= 25900 Then Value1 = 1;
If StrToNum(SymbolCode()) == 007820 And Close <= 14900 Then Value1 = 1;
If StrToNum(SymbolCode()) == 008060 And Close <= 9570 Then Value1 = 1;
If StrToNum(SymbolCode()) == 008260 And Close <= 4565 Then Value1 = 1;
If StrToNum(SymbolCode()) == 008700 And Close <= 3595 Then Value1 = 1;
If StrToNum(SymbolCode()) == 009150 And Close <= 69300 Then Value1 = 1;
If StrToNum(SymbolCode()) == 009275 And Close <= 33000 Then Value1 = 1;
If StrToNum(SymbolCode()) == 010170 And Close <= 2415 Then Value1 = 1;
If StrToNum(SymbolCode()) == 010955 And Close <= 79300 Then Value1 = 1;
If StrToNum(SymbolCode()) == 010960 And Close <= 4490 Then Value1 = 1;
If StrToNum(SymbolCode()) == 011070 And Close <= 139000 Then Value1 = 1;
If StrToNum(SymbolCode()) == 011155 And Close <= 32200 Then Value1 = 1;
If StrToNum(SymbolCode()) == 013360 And Close <= 16600 Then Value1 = 1;
If StrToNum(SymbolCode()) == 013367 And Close <= 108500 Then Value1 = 1;
If StrToNum(SymbolCode()) == 013580 And Close <= 17600 Then Value1 = 1;
If StrToNum(SymbolCode()) == 017000 And Close <= 9650 Then Value1 = 1;
If StrToNum(SymbolCode()) == 017370 And Close <= 5890 Then Value1 = 1;
If StrToNum(SymbolCode()) == 017510 And Close <= 6690 Then Value1 = 1;
If StrToNum(SymbolCode()) == 019990 And Close <= 6440 Then Value1 = 1;
If StrToNum(SymbolCode()) == 023350 And Close <= 10100 Then Value1 = 1;
If StrToNum(SymbolCode()) == 028100 And Close <= 13200 Then Value1 = 1;
Else Value1 = 0;
Find(Value1);
2017-04-24
219
글번호 109108