커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

질문 드려요

안녕하세요 아래는 수식지왕님의 식을 이용 조건추가하려구합니다 조건은 일간차트 하기로하고요 이것식은 매수도 시장가 매도도 시장가 진입되는데요 매수진입가 대비 1.5피 하락하면 추가 1계약진입 매도진입가 대비 1.5피 상승하면 추가 1계약 진입 하도록 부탁드립니다 감사합니다 건강하십시요 input:renkoSize(5), length(0.01), NumATRs(0.01); var:j(0),k(0),renkoCnt(0),gubun(0),Sum(0),trSum(0),atrV(0),time1(0), filename("renko3.txt"),printOK(False),ma3 (0); array:OO[50](0),HH[50](0),LL[50](0),CC[50](0), TR[50](0), //True Range upperLine[50](0), //상단채널 lowerLine[50](0), //하단채널 maV[50](0); //이평선 If DayIndex == 0 Then { //break on session에 해당, 즉 일자가 바뀌면 새로 계산 gubun = 0; //방향을 초기화한다. 이후 형성되는 가격에 의해 방향이 계산 For j = 49 DownTo 1 { //금일 시가봉을 신규 추가 OO[j] = OO[j-1]; HH[j] = HH[j-1]; LL[j] = LL[j-1]; CC[j] = CC[j-1]; TR[j] = TR[j-1]; maV[j] = maV[j-1]; upperLine[j] = upperLine[j-1]; lowerLine[j] = lowerLine[j-1]; } OO[0] = C; //분봉의 종가를 기반으로 계산하기 때문에 당일 시초가 아니다 HH[0] = C; LL[0] = C; CC[0] = C; } Else { If gubun == 0 and CC[0] > 0 Then { //일 첫봉이 완성되지 않은 시점 If OO[0] - renkoSize >= C Then { gubun = -1; //하락 방향 CC[0] = OO[0] - renkoSize; //음봉 HH[0] = OO[0]; LL[0] = CC[0]; TR[0] = max(CC[1],HH[0]) - min(CC[1],LL[0]); //true range 계산식 참조 //macd 계산 당시와 마찬가지로 sum 값이 있을 때만 처리 If sum > 0 Then { sum = sum + CC[0] - CC[length]; //이평선 계산 원리 그대로, 현재가를 더하고 n봉전 가격 뺌 trSum = trSum + TR[0] - TR[length]; //true range의 합을 계산 maV[0] = Sum / length; //n개의 종가 합을 n으로 나누어 이동평균 계산 atrV = trSum / length; //ATR 계산식 참조 upperLine[0] = maV[0] + atrV * NumATRs; //상단 밴드 계산 lowerLine[0] = maV[0] - atrV * NumATRs; //하단 밴드 계산 } j = 0; if printOK then print(filename, "1=>,%.0f,%.0f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f", j,gubun,OO[j],HH[j],LL[j],CC[j]); } Else If OO[0] + renkoSize <= C Then { gubun = 1; //상승 방향 CC[0] = OO[0] + renkoSize; //양봉 HH[0] = CC[0]; LL[0] = OO[0]; TR[0] = max(CC[1],HH[0]) - min(CC[1],LL[0]); If sum > 0 Then { //계속 반복되는 공통 루틴이므로 if문 바깥으로 뺄까도 했으나 sum = sum + CC[0] - CC[length]; //더 복잡해지므로 copy & paste로 처리 trSum = trSum + TR[0] - TR[length]; maV[0] = Sum / length; atrV = trSum / length; upperLine[0] = maV[0] + atrV * NumATRs; lowerLine[0] = maV[0] - atrV * NumATRs; } j = 0; if printOK then print(filename, "2=>,%.0f,%.0f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f", j,gubun,OO[j],HH[j],LL[j],CC[j]); } } If LL[0] - renkoSize >= C Then { gubun = -1; renkoCnt = Int(Round((LL[0]-C)/renkoSize,9)); if renkoCnt > 49 then renkoCnt = 49; For j = 49 DownTo renkoCnt { OO[j] = OO[j-renkoCnt]; HH[j] = HH[j-renkoCnt]; LL[j] = LL[j-renkoCnt]; CC[j] = CC[j-renkoCnt]; TR[j] = TR[j-renkoCnt]; maV[j] = maV[j-renkoCnt]; upperLine[j] = upperLine[j-renkoCnt]; lowerLine[j] = lowerLine[j-renkoCnt]; } For j = renkoCnt-1 DownTo 0 { OO[j] = LL[j+1]; CC[j] = LL[j+1] - renkoSize; HH[j] = OO[j]; LL[j] = CC[j]; TR[j] = max(CC[j+1],HH[j]) - min(CC[j+1],LL[j]); If sum > 0 Then { sum = sum + CC[j] - CC[j+length]; trSum = trSum + TR[j] - TR[j+length]; maV[j] = Sum / length; atrV = trSum / length; upperLine[j] = maV[j] + atrV * NumATRs; lowerLine[j] = maV[j] - atrV * NumATRs; } if printOK then print(filename, "3=>,%.0f,%.0f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f",j,gubun,OO[j],HH[j],LL[j],CC[j]); } } Else If HH[0] + renkoSize <= C Then { gubun = 1; renkoCnt = Int(Round((C-HH[0])/renkoSize,9)); if renkoCnt > 49 then renkoCnt = 49; For j = 49 DownTo renkoCnt { OO[j] = OO[j-renkoCnt]; HH[j] = HH[j-renkoCnt]; LL[j] = LL[j-renkoCnt]; CC[j] = CC[j-renkoCnt]; TR[j] = TR[j-renkoCnt]; maV[j] = maV[j-renkoCnt]; upperLine[j] = upperLine[j-renkoCnt]; lowerLine[j] = lowerLine[j-renkoCnt]; } For j = renkoCnt-1 DownTo 0 { OO[j] = HH[j+1]; CC[j] = HH[j+1] + renkoSize; HH[j] = CC[j]; LL[j] = OO[j]; TR[j] = max(CC[j+1],HH[j]) - min(CC[j+1],LL[j]); If sum > 0 Then { sum = sum + CC[j] - CC[j+length]; trSum = trSum + TR[j] - TR[j+length]; maV[j] = Sum / length; atrV = trSum / length; upperLine[j] = maV[j] + atrV * NumATRs; lowerLine[j] = maV[j] - atrV * NumATRs; } if printOK then print(filename, "4=>,%.0f,%.0f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f", j,gubun,OO[j],HH[j],LL[j],CC[j]); } } Else If Time >= 151500 Then { //당일 종가봉에서 For j = 49 DownTo 1 { OO[j] = OO[j-1]; HH[j] = HH[j-1]; LL[j] = LL[j-1]; CC[j] = CC[j-1]; TR[j] = TR[j-1]; maV[j] = maV[j-1]; upperLine[j] = upperLine[j-1]; lowerLine[j] = lowerLine[j-1]; } If LL[1] > C Then { //종가가 이전 봉보다 아래 형성 OO[0] = LL[1]; CC[0] = C; HH[0] = OO[0]; LL[0] = CC[0]; TR[0] = max(CC[1],HH[0]) - min(CC[1],LL[0]); } Else If HH[1] < C Then { //종가가 이전 봉보다 위에 형성 OO[0] = HH[1]; CC[0] = C; HH[0] = CC[0]; LL[0] = OO[0]; TR[0] = max(CC[1],HH[0]) - min(CC[1],LL[0]); } Else { //종가가 이전 봉의 중간에 형성 OO[0] = C; CC[0] = C; HH[0] = C; LL[0] = C; TR[0] = max(CC[1],HH[0]) - min(CC[1],LL[0]); } If sum > 0 Then { sum = sum + CC[0] - CC[length]; trSum = trSum + TR[0] - TR[length]; maV[0] = Sum / length; atrV = trSum / length; upperLine[0] = maV[0] + atrV * NumATRs; lowerLine[0] = maV[0] - atrV * NumATRs; } j = 0; //채널 값을 새로이 계산 if printOK then print(filename, "5=>,%.0f,%.0f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f", j,gubun,OO[j],HH[j],LL[j],CC[j]); } } if sum == 0 and CC[length] > 0 then { for j = 0 to length - 1 { sum = sum + CC[j]; trsum = trsum + max(CC[j+1],HH[j]) - min(CC[j+1],LL[j]); } } ma3 = ma(C,91); if ma3 < OO[0] and ma3 < CC[1] Then buy("b",atmarket); if ma3 > OO[0] and ma3 > CC[1] Then sell("s",atmarket); //========================================================= 끝
프로필 이미지
회원
2019-02-28
280
글번호 126640
시스템
답변완료

문의

안녕하세요 선물차트상의 전고 전저에 호가잔량을표시나타나게 할수있읍니까
프로필 이미지
질갱이
2019-02-28
268
글번호 126634
지표
답변완료

수식 문의

아래 수식은 up,downvol 을 거래량지표에 적용하여 색깔로 구분해본 지표입니다. 이 지표에 나오는 데이타의 n봉간 누적분을 아래와 같이 표현하고 싶습니다. 질문 1 :: n봉 기간의 downvol - Upvol값을 누적하여 지표로 표현하고 싶습니다. 질문2 :: n봉 기간의 (누적 downvol - Upvol )값이 양수이면 거래량 지표에 **색을, 음수이면 @@색을 적용하고 싶습니다. 질문 3 :: n봉 기간의 (누적 downvol - Upvol )값이 양수이면 캔들에 **색을, 음수이면 @@색을 적용하고 싶습니다. 인터페이스는 불친절하지만 게시판 답변이 친절하여 덕분에 예트를 더욱 사랑하게 되었습니다. ㅋㅋ 앞으로도 잘 부탁드립니다. ㅎ If (Upvol > downvol) or (Upvol == downvol and Upvol >= Upvol[1]) Then { Plot1(V, "상승"); Plot2(0, "하락"); } Else { Plot1(0, "상승"); Plot2(V, "하락"); }
프로필 이미지
부똘이
2019-02-28
272
글번호 126631
지표
답변완료

수정수식6

60971변 전일종가 추가부탁드립니다
프로필 이미지
용각산
2019-02-28
266
글번호 126629
지표
답변완료

볼밴 수식 부탁드립니다.

1) 2분봉.. (20,2) 기본 볼밴에 5분봉 (20.2) , 30분봉 (20,2) 볼밴도 함께 표현 될수 있는 수식을 부탁드립니다.. 2) 위 수식 중에 분봉과 (20,2)값을 수정(변수) 가능하도록 부탁드립니다.
프로필 이미지
레드골드
2019-02-28
259
글번호 126628
지표
답변완료

수식 부탁 드립니다.

안녕하세요. 아래 수식 작성이 가능하신지요? 부탁드립니다. 오후 9시 이후에만 진입. 캘트너 채널 상향 돌파후 다음봉이 양봉일때 매수 캘트너 채널 하향 돌파후 다음봉이 음봉일때 매도 청산은 샹들리에 청산 적용. 감사합니다.
프로필 이미지
ctosec
2019-02-27
251
글번호 126627
시스템
답변완료

질문드립니다.

이틀전 종가보다 어제종가가 10%이상 상승한 종목 검색식 부탁드립니다.
프로필 이미지
stockric
2019-02-27
295
글번호 126626
종목검색
답변완료

문의합니다

일목에서 후행스팬이 기준선 상향돌파시 매수 하향돌파시 매도 수식 작성 부탁드립니다.
프로필 이미지
별무리
2019-02-27
230
글번호 126625
시스템
답변완료

수식은 아니고 시스템적인것 문의드립니다.

안녕하세요? 키움을 쓰다가 넘어오기 위해 공부중입니다. 예스트레이더,랭귀지,스팟 등을 이용하여 특정 조건(단순한 조건입니다. 거래량이 일정이상이라든가 하는 정도로..)의 종족들을 자동으로 포착하고 미리 짜 놓은 수식에 따라 자동매매하는것이 가능할까요? 아니면 외부 엑셀이나 파이썬등을 같이 이용해야 가능한가요? 아니면 불가능할까요? 파이썬은 다룰줄 압니다. 가능할지 궁급합니다. 혹시 가능하다면 어떤 구조정도인지만 알려주시면 좋겠습니다. 감사합니다!
프로필 이미지
어느강아지의죽음
2019-02-27
284
글번호 126624
시스템