커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내

안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
프로필 이미지
예스스탁
2026-02-27
1751
글번호 230811
지표
답변완료

외국인 수급

KP200연결선물지수 일봉 차트 사용중입니다. 외국인 일별 선물 + 현물 합계 수급을 그래프 표시하고 싶습니다. 감사합니다.
프로필 이미지
묻어가는자
2021-01-06
659
글번호 145164
지표
답변완료

수식좀 요청 드립니다.(이평)

* 추운 날씨에 감기 조심 하십시요. * 요청사항 : 이평선 지표 하나만 요청 드립니다. → 스톡 형태의 0선 기준 형태 0선 : 20봉 이평선 윗선 : 100봉 최고가 - 20봉 이평선 (100봉 최고가에서 20봉 이평값을 뺀 수치) 아래선 : 20봉 이평선 - 100봉 최저가 (20봉이평값에서 100봉 최저가값을 뺀 수치) 즉 20봉 기준선으로 100봉의 고가와 저가 차이가 표시 되도록 부탁 좀 드립니다. * 항싱 많은 도움에 고맙습니다.
프로필 이미지
요타
2021-01-06
507
글번호 145163
강조
답변완료

문의드립니다

감사합니다 1 매수진입 종가 > 종가 최근 20봉 기간동안의 최저점*1.1 매수청산 종가 < 진입이후 종가 최고점*0.8 매도진입 종가 < 종가 최근 20봉 기간동안의 최고점*0.9 매도청산 종가 > 진입이후 종가 최저점*1.2 2 매수진입 종가 > 10일 이평선의 최근 20봉 기간동안의 최저점*1.1 매수청산 종가 < 진입이후 10일 이평선의 최고점*0.8 매도진입 종가 < 10일 이평선의 최근 20봉 기간동안의 최고점*0.9 매도청산 종가 > 진입이후 10일 이평선의 최저점*1.2
프로필 이미지
파인애플
2021-01-06
503
글번호 145162
시스템
답변완료

DMI 값 세부공식 문의

다른증권사와 DMI 값이 차이가 있어 문의를 하여 알려주신 키움수식의 답변의 값이 실제 키움 HTS의 지표의 값과 차이가 있습니다. 그래서 키움의 함수 설명 확인해보니 알려주신 수식과 일치합니다. 혹시 짐작되시는 부분 있으면 알려주시면 감사하겠습니다. 다른 증권사에서도 예스랭귀지의 DMI 값을 사용하고 싶습니다. 예스랭귀지에서 적용하는 ADX DiPlus DiMinus 세부공식을 알려주시면 감사하겠습니다. //----------------------------------------------------- // 알려주신 키움 세부공식 input : Period(10); var : Plus(0),Minus(0),adxv(0); plus = Ema(iff(H-H[1]>0 && H-H[1]>L[1]-L,H-H[1],0),Period)/ Ema(max(max(H-L,abs(C[1]-H)),abs(C[1]-L)),Period)*100; Minus = ema(iff(L[1]-L>0 && H-H[1]<L[1]-L,L[1]-L,0),Period)/ ema(max(max(H-L,abs(C[1]-H)),abs(C[1]-L)),Period)*100; adxv = Ema(abs(plus-Minus)/(plus+Minus),period)*100; plot1(plus); plot2(minus); plot3(adxv); //-----------------------------------------------------
프로필 이미지
여유의공간
2021-01-06
541
글번호 145161
지표

상박이 님에 의해서 삭제되었습니다.

프로필 이미지
상박이
2021-01-06
13
글번호 145160
지표
답변완료

시스템 수정

자주 질문드려 죄송합니다 수정해주신 수식을 확인해보니 제가 의도한대로 적용되고 있는것 같습니다 그런데 아래의 올려주신 수식이 1번식과 2번식이 있는데요 수식을 여러차례 확인해보아도 차이점이 없는것 같아 다시한번 질문드려봅니다. 확인부탁드리면 감사하겠습니다 ------------------------------------------------ 안녕하세요 예스스탁입니다. 1번식은 매수1,매수2,매수3 중에 한개이상 진입하고 최저가 진입가에서 3%,5%,10%에서 매수4,매수5,매수6으로 추가 진입합니다. 만약 매수1,매수2,매수3이 모두 진입한 이후에 3개진입의 최저가에서 3%,5%,10%에서 매수4,매수5,매수6으로 추가 진입을 원하시면 2번식 이용하시면 됩니다. 1 INPUT : 매수(0), 매도조건(1); var : cond(False),LP(0); var1 = ma(C,3); var2 = ma(C,5); var3 = ma(C,10); var4 = ma(C,60); value1 = 0; if value1 == 0 and C < Var4 and CrossDown(c,var3) and cond == False Then { if MarketPosition == 0 or (MarketPosition == 1 and C < LP and Condition1 == False) Then { value1 = 1; Buy("매수3"); } } if value1 == 0 and C < var4 and CrossDown(c,var2) and cond == False Then { if MarketPosition == 0 or (MarketPosition == 1 and C < LP and Condition1 == False) Then { value1 = 1; Buy("매수2"); } } if value1 == 0 and C < Var4 and CrossDown(c,var1) and cond == False Then { if MarketPosition == 0 or (MarketPosition == 1 and C < LP and Condition1 == False) Then { value1 = 1; Buy("매수1"); } } if MarketPosition == 1 Then { if 매수 == 1 Then Cond = true; if CurrentContracts > CurrentContracts[1] and LatestEntryName(0) == "매수1" Then { if LP == 0 or (LP > 0 and LatestEntryPrice(0) < LP) Then LP = LatestEntryPrice(0); Condition1 = true; } if CurrentContracts > CurrentContracts[1] and LatestEntryName(0) == "매수2" Then { if LP == 0 or (LP > 0 and LatestEntryPrice(0) < LP) Then LP = LatestEntryPrice(0); Condition2 = true; } if CurrentContracts > CurrentContracts[1] and LatestEntryName(0) == "매수3" Then { if LP == 0 or (LP > 0 and LatestEntryPrice(0) < LP) Then LP = LatestEntryPrice(0); Condition3 = true; } if CurrentContracts > CurrentContracts[1] and LatestEntryName(0) == "매수4" Then { Condition4 = true; } if CurrentContracts > CurrentContracts[1] and LatestEntryName(0) == "매수5" Then { Condition5 = true; } if CurrentContracts > CurrentContracts[1] and LatestEntryName(0) == "매수6" Then { Condition6 = true; } if Condition3 == true or Condition2 == true or Condition1 == true Then { if Condition4 == False Then Buy("매수4",AtLimit,LP*0.97); if Condition4 == true and Condition5 == False Then Buy("매수5",AtLimit,LP*0.95); if Condition4 == true and Condition5 == true and Condition6 == False Then Buy("매수6",AtLimit,LP*0.90); } if 매도조건 == 1 Then { ExitLong("bx1",AtLimit,AvgEntryPrice*1.05,"",Floor(MaxContracts*0.2),1); ExitLong("bx2",AtLimit,AvgEntryPrice*1.08,"",Floor(MaxContracts*0.5),1); ExitLong("bx3",AtLimit,AvgEntryPrice*1.10); } if 매도조건 == 2 Then { ExitLong("bx",AtLimit,AvgEntryPrice*1.15); } } Else { LP = 0; Condition1 = False; Condition2 = False; Condition3 = False; Condition4 = False; Condition5 = False; Condition6 = False; } 2 INPUT : 매수(0), 매도조건(1); var : cond(False),LP(0); var1 = ma(C,3); var2 = ma(C,5); var3 = ma(C,10); var4 = ma(C,60); value1 = 0; if value1 == 0 and C < Var4 and CrossDown(c,var3) and cond == False Then { if MarketPosition == 0 or (MarketPosition == 1 and C < LP and Condition1 == False) Then { value1 = 1; Buy("매수3"); } } if value1 == 0 and C < var4 and CrossDown(c,var2) and cond == False Then { if MarketPosition == 0 or (MarketPosition == 1 and C < LP and Condition1 == False) Then { value1 = 1; Buy("매수2"); } } if value1 == 0 and C < Var4 and CrossDown(c,var1) and cond == False Then { if MarketPosition == 0 or (MarketPosition == 1 and C < LP and Condition1 == False) Then { value1 = 1; Buy("매수1"); } } if MarketPosition == 1 Then { if 매수 == 1 Then Cond = true; if CurrentContracts > CurrentContracts[1] and LatestEntryName(0) == "매수1" Then { if LP == 0 or (LP > 0 and LatestEntryPrice(0) < LP) Then LP = LatestEntryPrice(0); Condition1 = true; } if CurrentContracts > CurrentContracts[1] and LatestEntryName(0) == "매수2" Then { if LP == 0 or (LP > 0 and LatestEntryPrice(0) < LP) Then LP = LatestEntryPrice(0); Condition2 = true; } if CurrentContracts > CurrentContracts[1] and LatestEntryName(0) == "매수3" Then { if LP == 0 or (LP > 0 and LatestEntryPrice(0) < LP) Then LP = LatestEntryPrice(0); Condition3 = true; } if CurrentContracts > CurrentContracts[1] and LatestEntryName(0) == "매수4" Then { Condition4 = true; } if CurrentContracts > CurrentContracts[1] and LatestEntryName(0) == "매수5" Then { Condition5 = true; } if CurrentContracts > CurrentContracts[1] and LatestEntryName(0) == "매수6" Then { Condition6 = true; } if Condition3 == true and Condition2 == true and Condition1 == true Then { if Condition4 == False Then Buy("매수4",AtLimit,LP*0.97); if Condition4 == true and Condition5 == False Then Buy("매수5",AtLimit,LP*0.95); if Condition4 == true and Condition5 == true and Condition6 == False Then Buy("매수6",AtLimit,LP*0.90); } if 매도조건 == 1 Then { ExitLong("bx1",AtLimit,AvgEntryPrice*1.05,"",Floor(MaxContracts*0.2),1); ExitLong("bx2",AtLimit,AvgEntryPrice*1.08,"",Floor(MaxContracts*0.5),1); ExitLong("bx3",AtLimit,AvgEntryPrice*1.10); } if 매도조건 == 2 Then { ExitLong("bx",AtLimit,AvgEntryPrice*1.15); } } Else { LP = 0; Condition1 = False; Condition2 = False; Condition3 = False; Condition4 = False; Condition5 = False; Condition6 = False; }
프로필 이미지
쭈니오빠
2021-01-06
422
글번호 145157
시스템
답변완료

랜덤함수 관련 질문입니다.

15시 20~24분 사이에 랜덤으로 청산을 하고 싶습니다. (1분봉 사용). 청산시간 = 152000 + random(400); if stime == 청산시간 then exitlong ..... 이런식으로 하면, 15시 20~24분 사이에 청산이 될줄 알았는데, 랜덤으로 당일 청산이 안되는 경우가 생깁니다. 즉, 당일은 오버가 되버리고 다음날이다 다다음날 저 시간대에 청산이 되어버립니다.. 혹시 왜 그럴까요?? 아 선물이라서. 저 시간은 동시호가 시간도 아닙니다.. 감사합니다.
프로필 이미지
중박주식
2021-01-06
354
글번호 145156
시스템

ycchoi17 님에 의해서 삭제되었습니다.

프로필 이미지
ycchoi17
2021-01-06
119
글번호 145155
지표
답변완료

부탁 드립니다.

도움에 감사 드립니다. 그림과 같이 부탁 드립니다.
프로필 이미지
뮬리
2021-01-06
520
글번호 145154
지표