커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
6148
글번호 230811
답변완료
문의
도움 주셔서 감사드립니다.
아래 영웅문 수식 변환하여 종목검색에 활용하고자 합니다.
*수식*
a=(sum(if(C>C(1),1,0),Period)*sum(if(C>C(1),C-C(1),0),Period)/(sum(if(C>C(1),C-C(1),0),Period)+sum(if(C<C(1),C(1)-C,0),Period))-sum(if(C<C(1),1,0),Period)*sum(if(C<C(1),C(1)-C,0),Period)/(sum(if(C>C(1),C-C(1),0),Period)+sum(if(C<C(1),C(1)-C,0),Period)))/Period*100
*검색 조건*
a가 -50 이하인 종목 검색
2022-06-02
1409
글번호 159491
답변완료
문의드립니다.
수고 많으십니다.
키움 영웅문의 검색식을 예스스탁 검색식으로 사용하고져 합니다.
동일조건으로 검색 될 수 있도록 부탁드립니다.
★ 검색식
- [일] 0봉전 일목균형표(9,26,52) 1봉이내 후행스팬이 전환선 상향돌파후 지속
- [일] 0봉전 일목균형표(9,26,52) 1봉이내 후행스팬이 기준선 상향돌파후 지속
# 첨부
- 후행스팬이 전환선+기준선 돌파 검색
2022-06-01
1185
글번호 159490
맴맴잉 님에 의해서 삭제되었습니다.
2022-06-01
0
글번호 159489
답변완료
매도 청산식 문의 드립니다.
얼마전에 현물관련 분할매도 관련 시스템식을 요청드린적이 있었습니다.
그런데 해당식으로 적용했을때 적용이 안되는 경우가 있는데
이유를 찾을수가 없어 이렇게 글을 남깁니다.
요청드렸던 식은 아래와 같습니다.
위 그림파일을 보시면 1,2,3번 으로 동그라미를 쳐놨습니다.
1. 1번 동그라미에서 3%분할익절, 4% 분할일익절 청산이 되지 않은 이유가 궁금합니다.
2. 2번 동그라미에서는 아주 잘 적용 된것 같습니다. 이부분에선 질문이 없습니다.
3. 3번 동그라미에서는 B, C, D 에서 매수가 되었고, 3%에서 전량 매도청산되었는데, 해당부분에서는 4, 5, 7, 10%의 분할익절이 왜 적용안되었는지 궁금합니다.
확인부탁드리겠습니다.
그리고 항상 감사드립니다.
---------------------------------------------------------------
안녕하세요
예스스탁입니다.
예스랭귀지는 대소문자 구분하지 않습니다 h나 H나 같습니다.
#매수진입
if MarketPosition == 1 Then
{
#전봉대비 수량 감소(일부 청산발생을 위미)
if CurrentContracts < CurrentContracts[1] Then
{
#청산가 저장
var1 = LatestExitPrice(0);
#청산시간 저장
Var2 = TimeToMinutes(sTime);
}
#전봉대비 수량 증가(추가 진입발생을 의미)
if CurrentContracts > CurrentContracts[1] Then
{
#현재수량 저장
Var3 = CurrentContracts;
#고가 저장
Var4 = H;
}
#최근 진입후 최고가 계산
#현재봉 고가가 Var4보다 크면 Var4의 값을 현재봉 고가로 저장
if h > Var4 Then
Var4 = h;
#일부청산이 한번이상 발생하고
#현재 시간이 일부청산후 10분 이후이고
#종가가 청산가 보다 작으면
#전량 청산
if var1 > 0 and TimeToMinutes(sTime) >= Var2+10 and C < AvgEntryPrice then
ExitLong("bx");
#진입후 최고가가 평단가+3% 작으면
#평단가+3%를 셋팅하고 다음봉에서 해당가격 터치시 즉시 40% 청산
if Var4 < AvgEntryPrice*1.03 Then
ExitLong("3%익절",AtLimit,AvgEntryPrice*1.03,"",Floor(Var3*0.40));
#진입후 최고가가 평단가+4% 작으면
#평단가+4%를 셋팅하고 다음봉에서 해당가격 터치시 즉시 30% 청산
if Var4 < AvgEntryPrice*1.04 Then
ExitLong("4%익절",AtLimit,AvgEntryPrice*1.04,"",Floor(Var3*0.30));
#진입후 최고가가 평단가+5% 작으면
#평단가+5%를 셋팅하고 다음봉에서 해당가격 터치시 즉시 10% 청산
if Var4 < AvgEntryPrice*1.05 Then
ExitLong("5%익절",AtLimit,AvgEntryPrice*1.05,"",Floor(Var3*0.10));
#진입후 최고가가 평단가+6% 작으면
#평단가+6%를 셋팅하고 다음봉에서 해당가격 터치시 즉시 10% 청산
if Var4 < AvgEntryPrice*1.06 Then
ExitLong("7%익절",AtLimit,AvgEntryPrice*1.06,"",Floor(Var3*0.10));
#진입후 최고가가 평단가+10% 작으면
#평단가+10%를 셋팅하고 다음봉에서 해당가격 터치시 즉시 전량 청산
if Var4 < AvgEntryPrice*1.10 Then
ExitLong("10%익절",AtLimit,AvgEntryPrice*1.10);
}
Else#매수진입중이 아니면
{
#변수 0으로 초기화
var1 = 0;
Var2 = 0;
}
2022-06-01
894
글번호 159488
답변완료
문의드립니다.
수고 많으십니다.
키움 영웅문의 검색식을 예스스탁 검색식으로 사용하고져 합니다.
동일조건으로 검색 될 수 있도록 부탁드립니다.
★ 검색식
- [5분] 거래량 50000 이상 999999999 이하
# 첨부
- 5분봉 거래량 검색
2022-06-01
1159
글번호 159487
답변완료
수식 관련 질문.
표준편차가 2.1인 33일볼린저밴드의 상한선은 연속 10봉하락,
하한선은 연속 10봉 상승한 종목의 수식을 알고싶습니다
2022-06-01
1141
글번호 159486
답변완료
text 함수 좌표설정에 대해 .;..
Tx="무궁화꽃이피었습니다.";
var1 = Text_New(sDate, sTime, H, Tx);
Text_SetColor(var1, BLUE);
Text_SetStyle(var1, 1, 1);
Text_SetBold(var1, 1);
Text_SetSize(var1, 16);
위와같이 하여 좌표지점의 좌, 우, 상, 하 위치에 택스트를 표현하는 방법은 알겠습니다.
추가로 알고자 하는 것은
위 텍스트 좌표에서 좌측으로 이동시킬려면,
sTime[5]로 하면 같은 x축 산상에 봉의 5번째 앞의 위치로 되지요?.
그럼 봉의 뒷쪽.. 챠트의 여백위치에 표현하는 방법도 있는지 알고 싶습니다.
2022-06-01
1146
글번호 159485
답변완료
막대 그래프 표현 방법..
그래프 종류에 점 선 막대 일자 등이 있는데..
막대 그래프 표현 방법에 대해 문의 드립니다.
특정지점에 고점과 저점을 잡아 막대 그래프를 그리려면
동일 시각에 고점의 값을 할당해 특정 색으로 막대그래프를 그린 다음에
저점에 값을 할당해서 배경색으로 또 막대 그래프를 주어 표현하고 있습니다.
그렇게 하면 고점과 저점값으로 막대그래프를 표현할 수 있는데
이때 저점에서 그려준 배경색의 막대 그래프 때문에
다른 것들이 덫칠해져서 챠트가 지저분해 지고 여러가지 애로사항이 있습니다.
그래서 질문의 요지는
특정시간, 특정위치에 막대 그래프를 표현하고자 할 때
고점과 저점 사이에만 막대그래프가 만들어지게 하는 방법은 없는지..
현제까지 제가 아는 것은 막대그래프는 그냥 값을 지정하면
0부터 ~ 값까지 막대그래프가 그려지니까..
그것 아랫부분에 그려지는 모든 것들에 선과봉챠트 등 간섭? 을 받아
여러가지 보안작업이 필요한거 같습니다.
고점과 저점값을 지정하면
그 사이에만 막대그래프가 그려지는 그런 깔끔한 방법이 없을까요??
참고로 제가 하는 방법은 아래와 같습니다...
(시가 종가를 이용한 막대그래프를 표현하는 방법)
Plot87(iff(O > C, O, C), "oc", iff(O > C, 색1, 색4), def, 8);
#막대그래프로 설정
Plot88(iff(O > C, C, O), "co", 바탕색, def, 8);
#막대그래프로 설정
2022-06-01
1824
글번호 159484
답변완료
현재 진행중인 봉이나 지표 값을 가져오는 방법 문의
안녕하세요
1분봉을 주종목으로 놓고, 30분봉을 다른종목으로 설정하였구요.
9시10분에 9시~9시반까지 만들어지는 30분봉의 스토캐스틱 값을 가져오려고 하는데요,
전일 30분봉의 스토캐스틱 값을 가져오네요.
봉이 완성되는 시점인 9시30분에는 의도한 값을 가져오겠지만,
그전에 시간에 따라 바뀌어도 상관없으니 현시점에서의 값을 가져왔으면 하는데, 방법이 없을까요?
아니면 1분봉을 기준으로 30분봉의 스토캐스틱 값을 정확하지 않아도 비슷하게 가져올수 있는지 조언 부탁드립니다.
도움 부탁드립니다. 즐거운 하루 되세요.
StoK = Data2(StochasticsK(12,5));
if(sTime = 091000) Then
{
MessageLog("0901 StoK = %.2f",StoK);
}
2022-06-01
1415
글번호 159483