커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
5440
글번호 230811
답변완료
분봉데이터 엑셀로 받는법
종목의 원하는 날짜~날짜까지 날짜,시,고,저,종,거래량 같은 기본적인 데이터를 엑셀로 복사하고싶은데 어떻게 해야하나요?
2020-01-03
409
글번호 134877
상중하 님에 의해서 삭제되었습니다.
2020-01-03
0
글번호 134875
답변완료
부탁드립니다
수고하십니다
아래 수식에서 2선으로 plot1,plot2 청섹선과 적색선 두선으로 부탁드립니다
Input : shortPeriod(10), longPeriod(20);
var : PriceOsc(0),Direction(0);
PriceOsc = OSCP(shortPeriod, longPeriod);
if PriceOsc > PriceOsc[1] Then
Direction = 1;
if PriceOsc < PriceOsc[1] Then
Direction = -1;
if Direction == 1 and Direction != Direction[1] Then
var1 = PriceOsc[1];
if Direction == -1 and Direction != Direction[1] Then
var1 = PriceOsc[1];
plot1(var1,"선",iff(Direction==1,BLUE,RED));
2020-01-03
340
글번호 134872
답변완료
부탁드립니다.
아래수식을 65467번의 수식추가 부탁드립니다.
아래1번수식의 이부분을
Value1 = HiLoLineZigZag(length,종가사용여부,고,저,TL_NewBit);
2번수식에서 사용할수 있게 변환 부탁드립니다.
번거롭게 해서 죄송합니다.
한번더 부탁드립니다.
----------------------------------------------
1. (65467번의 수식)
Input:length(20),익청(20),손절(20);
Var:종가사용여부(0),TL_NewBit(0);
Array:고[10,4](0),저[10,4](0);
Value1 = HiLoLineZigZag(length,종가사용여부,고,저,TL_NewBit);
if value1 == 1 and value1 != value1[1] Then
{
Condition1 = true;
Condition2 = true;
}
if value1 == -1 and value1 != value1[1] Then
{
Condition3 = true;
Condition4 = true;
}
If MarketPosition <= 0 and value1 == 1 and Condition1 == true Then
Buy("B1",AtStop,고[2,1]);
If MarketPosition <= 0 and value1 == -1 and Condition4 == true Then
Buy("B2",AtStop,고[1,1]);
if MarketPosition == 1 Then
{
ExitLong("Bp",AtLimit,EntryPrice+PriceScale*익청,"",1,1);
}
If MarketPosition >= 0 and value1 == -1 and Condition3 == true Then
Sell("S1",AtStop,저[2,1]);
If MarketPosition >= 0 and value1 == 1 and Condition2 == true Then
Sell("S2",AtStop,저[1,1]);
if MarketPosition == -1 Then
{
ExitShort("Sp",AtLimit,EntryPrice-PriceScale*익청,"",1,1);
}
SetStoploss(PriceScale*손절,PointStop);
if MarketPosition == 1 Then
{
Condition1 = false;
Condition4 = false;
}
if MarketPosition == -1 Then
{
Condition2 = false;
Condition3 = false;
}
---------------------------------------------------------
2.
Input: length(20);
Var : j(0),jj(0),T(0);
var : 최종고가(0),최종저가(0),최종꼭지점(""),처리구분(""),TL1(0);
Array:HH[10,4](0),LL[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime
If Index == 0 Then
{
HH[1,1] = H;
LL[1,1] = L;
}
Condition1 = Highest(H,length) == H and 최종고가 <> H;
Condition2 = Lowest (L,length) == L and 최종저가 <> L;
처리구분 = "";
If Condition1 and Condition2 Then // 기간고점과 기간저점 동시 발생
{
If 최종꼭지점 == "저점" Then
{
If LL[1,1] > L Then 처리구분 = "저점처리";
Else 처리구분 = "고점처리";
}
Else If 최종꼭지점 == "고점" Then
{
If HH[1,1] < H Then 처리구분 = "고점처리";
Else 처리구분 = "저점처리";
}
}
Else If Condition1 Then 처리구분 = "고점처리";
Else If Condition2 Then 처리구분 = "저점처리";
#==========================================#
If 처리구분 == "고점처리" Then
{
T = 1;
최종고가 = H; // 신규고점을 체크하기 위해 저장
If 최종꼭지점 == "저점" Then
{
For j = 10 DownTo 2
{
For jj = 1 To 4
{
HH[j,jj] = HH[j-1,jj];
}
}
HH[1,1] = H;
HH[1,2] = Index;
HH[1,3] = sDate;
HH[1,4] = sTime;
TL1 = TL_New(LL[1,3],LL[1,4],LL[1,1],HH[1,3],HH[1,4],HH[1,1]);
TL_SetSize(TL1,1);
TL_SetColor(TL1,RED);
}
Else If HH[1,1] < H Then // 1번 고점보다 높은 고가 출현
{
HH[1,1] = H;
HH[1,2] = Index;
HH[1,3] = sDate;
HH[1,4] = sTime;
TL_SetEnd(TL1,HH[1,3],HH[1,4],HH[1,1]);
// 시작점은 변동없고 끝점의 위치가 현재 봉으로 연장된 것임
}
최종꼭지점 = "고점";
}
#==========================================#
If 처리구분 == "저점처리" Then
{
T = -1;
최종저가 = L;
If 최종꼭지점 == "고점" then
{
For j = 10 DownTo 2
{
For jj = 1 To 4
{
LL[j,jj] = LL[j-1,jj];
}
}
LL[1,1] = L;
LL[1,2] = Index;
LL[1,3] = sDate;
LL[1,4] = sTime;
TL1 = TL_New(HH[1,3],HH[1,4],HH[1,1],LL[1,3],LL[1,4],LL[1,1]);
TL_SetSize(TL1,1);
TL_SetColor(TL1,BLUE);
}
Else If LL[1,1] > L then
{
LL[1,1] = L;
LL[1,2] = Index;
LL[1,3] = sDate;
LL[1,4] = sTime;
TL_SetEnd(TL1,LL[1,3],LL[1,4],LL[1,1]);
}
최종꼭지점 = "저점";
}
-----------------------------------------------------------------------------
2020-01-03
336
글번호 134868
답변완료
수식 부탁드립니다
안녕하세요
항상 도움 주셔서 감사합니다
아래 OI 수식을 MACD 수식으로 부탁드립니다
파라볼릭 수식인데
Inputs: FastMovAvg(12), SlowMovAvg(26), MACDMovAvg(9);의
MACD 수식으로 사용하고 싶습니다
부탁 드립니다
감사합니다
Input : AF(0.02), AFMAX(0.2);
Var : Direction(0), SAR_Value(OI), AF_Value(.02), HighValue(OI), LowValue(OI), EP(0),CSARV(0),OIV(0);
OIV = Oi;
if OI == 0 Then
OIV = Oi[1];
if EP != 0 Then
{
if Direction == 1 then
{
EP = HighValue;
SAR_Value = SAR_Value + AF_Value * (EP - SAR_Value);
if OIV > HighValue then
{
HighValue = OIV;
AF_Value = AF_Value + AF;
if AF_Value >= AFMAX then AF_Value = AFMAX;
}
if OIV < SAR_Value then
{
Direction = -1;
SAR_Value = EP;
AF_Value = 0;
EP = 0;
LowValue = OIV;
}
}
else
{
EP = LowValue;
SAR_Value = SAR_Value + AF_Value * (EP - SAR_Value);
if OIV < LowValue then
{
LowValue = OIV;
AF_Value = AF_Value + Af;
if AF_Value >= AFMAX then AF_Value = AFMAX;
}
if OIV > SAR_Value then
{
Direction = 1;
SAR_Value = EP;
AF_Value = 0;
EP = 0;
HighValue = OIV;
}
}
CSarv = SAR_Value;
}
else
{
if SAR_Value != 0 && EP == 0 then
{
if Direction == 1 then
{
EP = HighValue;
AF_Value = AF;
SAR_Value = SAR_Value + AF_Value * (EP - SAR_Value);
if OIV > HighValue then
{
HighValue = OIV;
AF_Value = AF_Value + AF;
if AF_Value >= AFMAX then AF_Value = AFMAX;
}
}
else
{
EP = LowValue;
AF_Value = Af;
SAR_Value = SAR_Value + AF_Value * (EP - SAR_Value);
if OIV < LowValue then
{
LowValue = OIV;
AF_Value = AF_Value + AF;
if AF_Value >= AFMAX then AF_Value = AFMAX;
}
}
CSarv = SAR_Value;
}
else
{
if Direction == 0 then
{
if OIV > OIV[1] then Direction = 1;
else
if OIV < OIV[1] then Direction = -1;
}
else
{
if Direction == 1 then
{
if OIV < OIV[1] then
{
Direction = -1;
SAR_Value = HighValue;
CSarv = SAR_Value;
}
}
if Direction == -1 then
{
if OIV > OIV[1] then
{
Direction = 1;
SAR_Value = LowValue;
CSarv = SAR_Value;
}
}
}
LowValue = min(OIV, LowValue);
HighValue = max(OIV, HighValue);
}
}
plot1(OIV,"미결제약정");
plot2(CSARv,"미결파라볼릭"); //속성에서 점그래프
2020-01-03
362
글번호 134860
답변완료
수정부탁드립니다.
안녕하세요?
현재 교차매매되어있는데, 포지션 청산후 신호나올때 들어가도록 수정부탁드립니다.
감사합니다.
input : 양봉틱수(5),음봉틱수(5);
input : 익절틱수(50),손절틱수(50);
if O > C[1] and C == O+양봉틱수*PriceScale Then
buy();
if O < C[1] and C == O-음봉틱수*PriceScale Then
sell();
SetStopProfittarget(PriceScale*익절틱수,PointStop);
SetStopLoss(PriceScale*손절틱수,PointStop);
2020-01-03
312
글번호 134859
답변완료
수식문의드립니다
안녕하세요, 수식문의드립니다
1분봉을 기준으로
1. 1년내의 일간 거래량이 최대인 날의 시가,고가,저가,종가 값
2. N일(60일)내의 일간 거래량이 최대인 날의 시가,고가,저가,종가 값
3. N일(60일)내의 일간 20이평 값의 최대값, 최소값
을 구하고 싶습니다.
감사합니다.
2020-01-03
350
글번호 134855
답변완료
수식좀 부탁드립니다
키움수식인데 예스로 변환좀 부탁드립니다
수식1-상승
a=ma(c,기간,종류);
if(a>a(1)*(1+비율/100),a,0)
수식2-하락
a=ma(c,기간,종류);
if(a<a(1)*(1-비율/100),a,0)
수식3-횡보
a=ma(a,기간,종류);
if(a<=a(1)*(1+비율/100) && a(1)*(1-비율/100),a,0)
2020-01-03
366
글번호 134853
답변완료
안녕하세요 수정
안녕하세요
64674번 해선에서는 선두개안나옴 (수정부탁드립니다)
2020-01-03
340
글번호 134852