커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4374
글번호 230811
답변완료
지표 수식 질문드립니다.
안녕하세요, 어제 지표수식 관련 질문을 올렸었으나 해당 수식을 만들기 어렵다는 답변을 받았습니다. 질문은 다음과 같습니다.
----------------------------------------------------------------------------------------
분봉 차트에 현재가에 따라 호가창에 보여지는 매수 10호가와 매도 10호가의 범위를 표현하고 싶습니다. 가령, 현재가가 800원이면 차트에 매도 10호가인 809원과 매수 10호가인 790원을 표현하고 싶습니다. 문제는 호가단위가 변하는 지점인 천원, 5천원, 만원, 5만원, 80만원 등의 지점을 기준으로 하여 전후 10 호가에 대해서는 별도로 수식을 작성해야 한다는 것입니다. 가령, 현재가가 995원인 경우 매도호가를 구할 때 단순 계산으로 995+10이라고 하면 안 되고 995+4와 1000+50으로 나눠서 표시해야 실제 호가창과 같습니다. 반대로 가격이 1020원인 경우, 매수호가를 구할 때 1020-20과 1000-8을 나눠서 표시해야 실제 호가창과 같게 표시됩니다. 이 것을 각 호가단위 변동구간마다 고려해서 호가단위를 표시할 수 있는 식을 구현해주실 수 있나요?
----------------------------------------------------------------------------------------
답변을 받고 제가 지표수식을 대강 만들어봤는데요, 제가 만든 지표식은 다음과 같습니다.
var : maxprice(0), minprice(0), idx(0);
if c <= 990 then
{maxprice = c+10;
minprice = c-10;}
if 1050 < c and c <= 4950 then
{maxprice = c+50;
minprice = c-50;}
if 5100 < c and c <= 9900 then
{maxprice = c+100;
minprice = c-100;}
if 10500 < c and c <= 49500 then
{maxprice = c+500;
minprice = c-500;}
if 51000 < c and c <= 99000 then
{maxprice = c+1000;
minprice = c-1000;}
if 105000 < c and c <= 495000 then
{maxprice = c+5000;
minprice = c-5000;}
if 510000 < c then
{maxprice = c+10000;
minprice = c-10000;}
for idx = 1 to 10
{if 990+idx == c then
maxprice = 1000+5*(c-990);
minprice = c-10;}
{if 1000+5*idx == c then
maxprice = c+50;
minprice = 1000-(10-(c-1000)/5);}
{if 4950+5*idx == c then
maxprice = 5000+10*(10-(5000-c)/5);
minprice = c-50;}
{if 5000+10*idx == c then
maxprice = c+100;
minprice = 5000-5*(10-(c-5000)/10);}
{if 9900+10*idx == c then
maxprice = 10000+50*(10-(10000-c)/10);
minprice = c-100;}
{if 10000+50*idx == c then
maxprice = c+500;
minprice = 10000-10*(10-(c-10000)/50);}
{if 49500+50*idx == c then
maxprice = 50000+100*(10-(50000-c)/50);
minprice = c-500;}
{if 50000+100*idx == c then
maxprice = c+1000;
minprice = 50000-50*(10-(c-50000)/100);}
{if 99000+100*idx == c then
maxprice = 100000+500*(10-(100000-c)/100);
minprice = c-1000;}
{if 100000+500*idx == c then
maxprice = c+5000;
minprice = 100000-100*(10-(c-100000)/500);}
{if 495000+500*idx == c then
maxprice = 500000+1000*(10-(500000-c)/500);
minprice = c-5000;}
{if 500000+1000*idx == c Then
maxprice = c+10000;
minprice = 500000-500*(10-(c-500000)/1000);}
plot1(maxprice);
plot2(minprice);
그런데 제가 만든 지표를 적용시켜보니 두 가지 문제가 발생합니다. 첫째, 호가단위 변동구간을 전후한 지점에서의 매도 10호가가 실제 호가와 너무나 맞지 않게 표시됩니다(호가단위 변동구간을 제외한 지점에서는 제대로 표시됩니다). 둘째, 매수 10호가는 전체 구간에서 모두 맞지 않게 표시됩니다. 여기서 질문드립니다.
1. 제가 만든 지표에서 무엇이 문제인가요?
2. 만약 어제 답변해주신대로 해당 지표가 기술적으로 구현이 어려운 지표라면 어떤 부분이 구현이 어려운지 알려주실 수 있나요?
2018-04-20
143
글번호 118368
답변완료
강조식 부탁드립니다!
안녕하세요! 분봉이나 틱봉의 강조식 또는 검색식을 의뢰드려요!
현재 봉을 시작으로 뒤로 6, 11, 26, 76 번째 봉에 색으로 표시를 하여
눈에 잘띄게 말들고 싶습니다!
그리고 현재봉이 또 새로 생기면 뒤에 표시된 봉이 하나씩 앞으로 이동해서
표시가 계속 진행되길 원합니다!
1. 현재봉 기준에서 뒤로 6번째 봉을 색으로 표시가 나타나게끔 강조식이나 검색식을 부탁드립니다!
2. 현재봉 기준에서 뒤로 11번째 봉을 색으로 표시가 나타나게끔 강조식이나 검색식을 부탁드립니다!
3. 현재봉 기준에서 뒤로 26번째 봉을 색으로 표시가 나타나게끔 강조식이나 검색식을 부탁드립니다!
4. 현재봉 기준에서 뒤로 76번째 봉을 색으로 표시가 나타나게끔 강조식이나 검색식을 부탁드립니다!
부탁드려요! 감사합니다!
2018-04-20
147
글번호 118364
답변완료
스위칭
//매수진입
if 조건식 and marketposition==0 then
{
buy;
}
//매수진입2
if data2(bdate!=bdate[1] and 조건식) and marketposition==0 then
{
buy;
}
//매수청산
if marketposition==1 and 조건식 then
{
exitlong;
}
//매도진입
if 조건식 and marketposition==0
{
sell;
}
//매도진입2
if data3(bdate!=bdate[1] and 조건식) and marketposition==0 then
{
sell;
}
//매도청산
if marketposition==-1 and 조건식 then
{
exitshort
}
매수매도 잘 되고 있습니다만
스위칭을 추가하고 싶습니다.
예를 들어
매도포지션 보유중이였는데 매도청산과 매수진입2이 하나의 봉에서 이루어져야 하는데
매도청산만 되고 매수진입2이 안됩니다.
청산시점은 "봉 완성"으로 해놓은 상태구요, "조건만족시 즉시"는 개인적으로 원하지 않습니다.
2018-04-20
132
글번호 118358
답변완료
질문 드립니다.
dayclose(n) dayopen(n) dayhigh(n) daylow(n)
위의 함수들은 그 값이 내장되어있어서 챠트와 상관없이 불러들일수 있는거로 알고있는데
이게 코스피선물에서만 그런건지
아니면 코스피선물야간이나 코스닥선물 삼성전자선물이나 현물주식 등
모든 종목에 다 적용이 되는건지 궁금합니다.
좋은 하루 되세요. ^^
2018-04-20
119
글번호 118354
답변완료
다음봉이 언제 생성되는지
300틱에 건수300바를 이용하고 있는대요
다음바가 언제쯤 생성되는지 몰라서 진입타이밍이 안좋습니다.
그래서 다음바 생성이 언제인지좀 알려 주시면 감사하겠습니다.
예를들어 300건에 1바면 그 건수가 얼마나 차졌는지를 보는거요
2018-04-20
154
글번호 118353
관리자에 의해 프로그램 사용법 QnA로 이동되었습니다
2018-04-20
4
글번호 118352
답변완료
지표 검색식 질문드립니다.
안녕하세요, 궁금한게 생겨서 질문드립니다. 지표를 만들 때 지표 적용 시 코스닥 종목인지, 코스피 종목인지를 자동으로 판별해서 서로 다른 조건의 지표를 적용하도록 만들 수 있나요?
가령, 지표 식에는 20일 이동평균선에 대한 이격도 95%선과 98%선을 둘 다 써놓고, 실제 지표 적용 시 해당 종목이 코스피인지, 코스닥인지 판별해서 95%와 98% 둘 중 하나의 선을 그리게 할 수 있나요?
2018-04-20
120
글번호 118351
와라바다 님에 의해서 삭제되었습니다.
2018-04-20
12
글번호 118350
답변완료
좋은 주말 되십시요.
*요청1:분봉 차트에서 3일간 분봉 중 최고거래량보다 더크면 바로 매수 로직 좀부탁 드립니다.
*요청2:당일 매수 되었다면 매수 이전 의 당일 최고가 돌파시 매수 로직 부탁 드립니다.
즉 추가 매수 할려고 합니다.
if c>ma(c,5) Then buy(); 여기 이전 당일 최고가 돌파 하면 더매수 하고 십습니다.
혹시 매수 싯점이 가격이 당일 최고가 경우도 있으니 매수후 10분 경과 이후 부터
적용 입니다.
* 고맙습니다. 수고하십시요.
2018-04-20
118
글번호 118349