커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

식수정 75237

안녕하세요 75237에 대한식 수정부탁드립니다 매수 하이프라이스 선발생후 선돌파후 양봉발생시 매수.5분봉에서 20선위에 있을것. 매도 하이프라이스 선발생후 선하향후 음봉발생시 매도.5분봉에서 20선 아래있을것 . 수고하세요
프로필 이미지
아트정
2022-03-06
1326
글번호 156959
시스템
답변완료

시스템식 문의 드립니다.

시스템 식 작성중에 어려운 부분이 있어 글 작성합니다. 1. if condition1 == true Then Buy("1차매수",AtMarket); 위 식에서 atmarket를 사용했을때에 투자금액을 변수로 넣고 싶습니다. 예를들어 if condition1 == true Then Buy("상한가매수",AtStop,상한가,Floor(금액1/min(NextBarOpen,상한가))); 상한가 매수시스템식에서 floor 이후에 조건을 통해서 금액을 변수로 넣을수가 있었는데.... atmarket이나 onclose 같은 경우 (뒤에 금액이 안붙어도 되는경우) 는 투자금액을 변수로 어떻게 넣어야 할지 잘 모르겠습니다. 2. 나름 식을 작성하였는데.. 생각대로 안되는 부분이 있어 요청드립니다. 2-1 당일에는 매수만 되고 다음날에는 매도가 되어야 하는데 다음날에도 매수가 되는 경우가 있다 .어떻게 해야 하나요?? 2-2 추매이후에는 매도가 안되는데 왜 안될까요 ??? 3. IsEntryName("S1") == true 옆 수식에서 가장 마지막으로 들어간 매수진입명 이 맞는지요?? 밑에 제가 나름 열심히 만들었는데 한번 확인 부탁드리겠습니다. ----------------------------------------------------------------------- input :금액1(500000),상한가(36500),손절금액(300000); input : 익절(3),익절2(1); var : cnt(0),sum(0),mav(0),DD(0); var : day(0),entry(False),AP(0),TT(0); var : LL(0),RR(0),rate(0); if Bdate != Bdate[1] Then Condition1 = False; if sTime > 120000 and C[0] >= DayClose(1)*1.265 Then Condition1 = true; if TotalTrades > TotalTrades[1] Then entry = False; #여기서 부터 매도하기. if condition1 == true OR LatestExitName(1) == "4%익절" Then Buy("상한가매수",AtStop,상한가,Floor(금액1/min(NextBarOpen,상한가))); if condition1 == true and IsEntryName("상한가매수") == true Then Buy("BS1(상풀)",AtLimit,상한가*0.955,Floor(금액1/min(NextBarOpen,상한가*0.955))); if condition1 == true Then Buy("BS1",AtLimit,Dayclose(1)*1.235,Floor(금액1/min(NextBarOpen,Dayclose(1)*1.235))); if condition1 == true and IsEntryName("BS1") == true and sdate >= EntryDate+1 and day <=1 Then Buy("S1",AtLimit,Dayclose(1)*1.19,Floor(금액1/min(NextBarOpen,Dayclose(1)*1.19))); if condition1 == true and IsEntryName("BS1") == true and sTime == 150800 Then Buy("3시10분매수(1-1)",AtMarket); if condition1 == true and IsEntryName("3시10분매수(1-1)") == true and sTime == 151300 Then Buy("3시15분매수(1-2)",AtMarket); if condition1 == true and IsEntryName("3시10분매수(1-1)") == true and sTime == 151700 Then Buy("3시19분매수(1-3)",AtMarket); if condition1 == true and MarketPosition == 0 and sTime == 150800 Then Buy("3시10분매수(2-1)",AtMarket); if condition1 == true and IsEntryName("3시10분매수(2-1)") == true and sTime == 151300 Then Buy("3시15분매수(2-2)",AtMarket); if condition1 == true and IsEntryName("3시10분매수(2-1)") == true and sTime == 151700 Then Buy("3시19분매수(2-3)",AtMarket); if MarketPosition == 1 and day >=2 and DayOpen*1.04>=DayHigh Then Buy("S1(NEXT)",AtLimit,DayHigh*0.92,Floor(금액1/min(NextBarOpen,DayHigh*0.92))); #여기서 부터 매도하기. if MarketPosition == 1 Then { if LL == 0 then LL = L; Else { if L < LL then LL = L; } RR = (LL-AVGEntryPrice)/AVGEntryPrice*100; if RR >= -0.9 Then Rate = 익절; if RR >= -2.9 and RR < -0.9 Then Rate = (익절+RR); if RR < -2.9 Then Rate = 0.3; ExitLong("3%익절",AtLimit,AVGEntryPrice*(1+Rate/100),"",Floor(MaxContracts*0.5)); ExitLong("4%익절",AtLimit,AVGEntryPrice*(1.01+Rate/100)); } Else LL = 0; #---------------------------------------------------------------------------- # 3%, 4% 매도 청산 #---------------------------------------------------------------------------- if MarketPosition == 1 AND IsEntryName("S1") == true or IsEntryName("S1(NEXT)") == true or IsEntryName("BS1(상풀)") == true Then { ExitLong("0.3%익절",AtLimit,AVGEntryPrice*1.003,"",Floor(MaxContracts*0.5)); ExitLong("1%익절",AtLimit,AVGEntryPrice*1.1); } Else LL = 0; #---------------------------------------------------------------------------- # 0.3%, 1% 매도 청산 #---------------------------------------------------------------------------- if MarketPosition == 1 Then if sdate >= EntryDate+1 and sTime == 100000 Then { ExitLong("다음날 10시청산"); } #---------------------------------------------------------------------------- # 다음날 10시 청산 #---------------------------------------------------------------------------- if MarketPosition == 1 Then ExitLong("손절",AtStop,AvgEntryPrice-손절금액/CurrentContracts); #---------------------------------------------------------------------------- # 손절
프로필 이미지
맴맴잉
2022-03-06
1376
글번호 156958
시스템
답변완료

수식 질문드립니다.

수식 합치는거좀 부 탁드립니다. Option.GetATMCallRecent(n) Option.GetATMPutRecent(n) 요걸 수정하기 위함입니다. 1. 홈페이지 스팟 메뉴얼에 있는식입니다. var Start; var B1CallCode; var B1PutCode; var S1CallCode; var S1PutCode; function Main_OnStart() { Main.MessageLog("시작"); Start = 0; } function C1_OnRiseSignal(Signal) { Main.MessageLog("신호완성/"+Signal.signalKind); if (Signal.signalKind == 1 ) { Start = 1; B1CallCode = Option.GetATMCallRecent(n); var B1CallPrice = Option.GetAskByCode(B1CallCode,2); A1.OrderBuy(B1CallCode, Vol1, B1CallPrice, 0); Main.MessageLog("콜매수"); } if (Start == 1 && Signal.signalKind == 2 ) { var B1xCallPrice = Option.GetBidByCode(B1CallCode, 2); A1.OrderSell(B1CallCode, Vol1, B1xCallPrice, 0); Main.MessageLog("콜매수청산"); } if (Signal.signalKind == 3 ) { Start = 1; S1PutCode = Option.GetATMPutRecent(n); var S1PutPrice = Option.GetAskByCode(S1PutCode,2); A1.OrderBuy(S1PutCode, Vol1, S1PutPrice, 0); Main.MessageLog("풋매수"); } if (Start == 1 && Signal.signalKind == 4 ) { var S1xPutPrice = Option.GetBidByCode(S1PutCode, 2); A1.OrderSell(S1PutCode, Vol1, S1xPutPrice, 0); Main.MessageLog("합성선물매도청산"); } } 2.1번의 식에다가 아래 easy language 식을 넣고 싶습니다. var : c2(0,Data2); var : n(0); c2 = Data2(c); if c2>0 Then n=ceiling(c2*7/2.5); if c2>1 Then n=ceiling(c2*5/2.5); if c2>2 Then n=ceiling(c2*4/2.5); if c2>3 Then n=ceiling(c2*3/2.5); if c2>7 Then n=ceiling(c2*2.5/2.5); #Plot1(n); 3. 여기서 문제가 메뉴얼에는 data2 부터 쓰라고 나와있는데 사진처럼 data1 써도 상관없는거죠? data1에서 datamanager 불러지던데요. "888"은 data manager의 data 입니다. 감사합니다.
프로필 이미지
캣피쉬
2022-03-06
1887
글번호 156957
시스템
답변완료

지표 질문입니다

틱 차트에서 D-2일 고가와 D-3일 고가를 연결하는 선을 그린다 D-1일 고가와 D-2일 고가를 연결하는 선을 그린다 D-1일 고가와 당일 고가를 연결하는 선을 그린다 D-2일 저가와 D-3일 저가를 연결하는 선을 그린다 D-1일 저가와 D-2일 저가를 연결하는 선을 그린다 D-1일 저가와 당일 저가를 연결하는 선을 그린다 감사합니다
프로필 이미지
회원
2022-03-06
1298
글번호 156956
지표
답변완료

시스템 수식문의(전일가격참조)

수고가 많으십니다. 아래와 같은 수식을 작성하고자 합니다. 매매조건(10분봉 기준) 전일 09:00~09:10 이 양봉이면 금일 09:00~09:10 entry long 전일 09:00~09:10 이 음봉이면 금일 09:00~09:10 entry sell 당일 재진입금지
프로필 이미지
하운드독
2022-03-05
1394
글번호 156955
시스템
답변완료

문의드립니다.

10일전 첫 1분봉의 거래대금이 50억 이상인 종목들을 검색하고자 합니다. 기준봉 및 검색에 필요한 최소 기간에 대한 입력 숫자도 언급부탁드립니다. 감사합니다.
프로필 이미지
후박나무
2022-03-06
1136
글번호 156954
종목검색
답변완료

문의드립니다.

스토어캐스틱 퍼스트 59에서 65사이에 양봉캔들발생 매도. 캔들종가가 65 위의 있어야 하고 매수한 그 캔들의 고가보다 높게 봉완성되면 손절청산. 익절200틱. 수고하세요.
프로필 이미지
아침
2022-03-06
1098
글번호 156953
시스템
답변완료

문의드립니다.

스토어캐스틱 퍼스트 35에서 41사이에 음봉캔들 발생 매수. 캔들종가가 35보다 아래의 있고 매수한 그 캔들의 저가보다 낮게 봉완성되면 손절청산. 익절200틱. 부탁드립니다. 수고하세요.
프로필 이미지
아침
2022-03-06
1222
글번호 156952
시스템
답변완료

수식 문의드립니다.

1분봉 스토캐(5,3,3) 골든크로스 및 5분봉 스토캐 K>D 일때 매수 1분봉차트에서 스토캐 및 5분봉 스토캐 값을 구해서 전략에 사용하려고 합니다. 항상 도움주셔서 감사합니다.
프로필 이미지
tadd
2022-03-04
1158
글번호 156951
시스템