커뮤니티

예스랭귀지 Q&A

글쓰기

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

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

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

프로필 이미지
파워
2024-03-01
853
글번호 177090
지표
답변완료

종목검색식문의

안녕하세요 수고하십니다. 최근 4주 사이 52주 신저가를 기록한 종목을 제외하고 싶은데 코드 좀 짜주실 수 있으실까요? 감사합니다.
프로필 이미지
깅창
2024-03-01
871
글번호 177089
종목검색

예스트레이더로 지표 변화부탁드립니다..

(수식1) SF (C-lowest(L,Period))/(highest(H,Period)-lowest(L,Period))*100 (수식2) WR (highest(H,Period) - C) / (highest(H, Period) - lowest(L, Period)) * (100) - 지표조건설정 Period : 20
프로필 이미지
가림
2024-03-01
936
글번호 177088
지표
답변완료

시스템 작성의뢰

수고 하십니다 ! 이동평균선 1선과 7680 선이 다운크로스 한다음 240 이평선과 960 이평선의 간격이 20틱이상 벌어지고 1 선과 7680 선이 업크로스 하면 매수를 하고 이동평균선 1선과 7680 선이 업크로스 한다음 240 이평선과 960 이평선의 간격이 20틱이상 벌어지고 1 선과 7680 선이 다운크로스 하면 매도를 하는 수식을 부탁 드립니다 !
프로필 이미지
tnsflwls
2024-03-01
992
글번호 177087
시스템
답변완료

차트에 적용된 시스템 인데요

안녕하세요. 아래수식은 차트에 적용된 매수 매도 수식인데요(전략생성기로 만든) 내보내기 하여 매도식은 삭제하고 매수식만을 이용해서 buy()를 find(1)로 변경해서 종목검색을 하는데 조건이 맞으면 당일에 Onclose가 표시가 되는 것도 있고 며칠전에 매수신호가 나오고 매도신호가 안나오면 Onclose가 표시가 안되는 것이 섞여서 검색이 됩니다. 그래서 저는 검색했을 때 당일에 Onclose만 나온 종목만 검색이 되었으면 합니다. 따로 검색식이 있으면 좋겠습니다..(다른 전략에도 적용할 수 있게) 부탁드립니다. 추가로 아래식에 매도부분에 BII도 하락했을 때도 추가해 주시면 감사하겠습니다. Input : B_A_Period1(9), B_A_Period2(26), B_A_Period3(52); Input : B_B_Period1(12), B_B_Period2(26), B_B_Period3(9); Input : B_C_Period1(10); Input : B_D_Period1(9), B_D_Period2(26), B_D_Period3(52); Input : B_E_Period1(9), B_E_Period2(26), B_E_Period3(52); Input : S_A_Period1(12), S_A_Period2(26), S_A_Period3(9); Var : B_A_Value1(0), B_A_Value2(0), B_A_Value3(0), B_A_Value4(0), B_A_Value5(0), B_A_Value6(0), B_A_Value7(0); Var : B_A_CondResult(FALSE), B_A_TempResult(FALSE), B_A_Condition1(FALSE); Var : B_B_value1(0), B_B_value2(0); Var : B_B_CondResult(FALSE), B_B_TempResult(FALSE), B_B_Condition2(FALSE); Var : B_C_value1(0); Var : B_C_CondResult(FALSE), B_C_TempResult(FALSE), B_C_Condition1(FALSE); Var : B_D_Value1(0), B_D_Value2(0), B_D_Value3(0), B_D_Value4(0), B_D_Value5(0), B_D_Value6(0), B_D_Value7(0); Var : B_D_CondResult(FALSE), B_D_TempResult(FALSE), B_D_Condition3(FALSE); Var : B_E_Value1(0), B_E_Value2(0), B_E_Value3(0), B_E_Value4(0), B_E_Value5(0), B_E_Value6(0), B_E_Value7(0); Var : B_E_CondResult(FALSE), B_E_TempResult(FALSE), B_E_Condition1(FALSE); Var : S_A_value1(0), S_A_value2(0); Var : S_A_CondResult(FALSE), S_A_TempResult(FALSE), S_A_Condition3(FALSE); B_A_Value1 = (highest(H,B_A_Period1)+lowest(L,B_A_Period1))/2; B_A_Value2 = (highest(H,B_A_Period2)+lowest(L,B_A_Period2))/2; B_A_Value3 = C; B_A_Value4 = (B_A_Value1+B_A_Value2)/2; B_A_Value5 = (highest(H,B_A_Period3)+lowest(L,B_A_Period3))/2; B_A_Value6 = B_A_Value4[25]; B_A_Value7 = B_A_Value5[25]; B_B_value1 = EMA(Close,B_B_Period1)-EMA(Close,B_B_Period2); B_B_value2 = EMA(B_B_value1,B_B_Period3); B_C_value1 = MA(Close,B_C_Period1); B_D_Value1 = (highest(H,B_D_Period1)+lowest(L,B_D_Period1))/2; B_D_Value2 = (highest(H,B_D_Period2)+lowest(L,B_D_Period2))/2; B_D_Value3 = C; B_D_Value4 = (B_D_Value1+B_D_Value2)/2; B_D_Value5 = (highest(H,B_D_Period3)+lowest(L,B_D_Period3))/2; B_D_Value6 = B_D_Value4[25]; B_D_Value7 = B_D_Value5[25]; B_E_Value1 = (highest(H,B_E_Period1)+lowest(L,B_E_Period1))/2; B_E_Value2 = (highest(H,B_E_Period2)+lowest(L,B_E_Period2))/2; B_E_Value3 = C; B_E_Value4 = (B_E_Value1+B_E_Value2)/2; B_E_Value5 = (highest(H,B_E_Period3)+lowest(L,B_E_Period3))/2; B_E_Value6 = B_E_Value4[25]; B_E_Value7 = B_E_Value5[25]; B_A_Condition1 = B_A_Value1 > B_A_Value1[1]; B_A_TempResult = B_A_Condition1; B_A_CondResult = B_A_TempResult; B_B_Condition2 = B_B_value1 > B_B_value2; B_B_TempResult = B_B_Condition2; B_B_CondResult = B_B_TempResult; B_C_Condition1 = B_C_value1 < C; B_C_TempResult = B_C_Condition1; B_C_CondResult = B_C_TempResult; B_D_Condition3 = B_D_Value1[0] >= B_D_Value2[0]; B_D_TempResult = B_D_Condition3; B_D_CondResult = B_D_TempResult; B_E_Condition1 = B_E_Value2 > B_E_Value2[1]; B_E_TempResult = B_E_Condition1; B_E_CondResult = B_E_TempResult; If B_A_CondResult and B_B_CondResult and B_C_CondResult and B_D_CondResult and B_E_CondResult Then { Buy(); } S_A_value1 = EMA(Close,S_A_Period1)-EMA(Close,S_A_Period2); S_A_value2 = EMA(S_A_value1,S_A_Period3); S_A_Condition3 = CrossDown(S_A_value1, S_A_value2); S_A_TempResult = S_A_Condition3; S_A_CondResult = S_A_TempResult; If S_A_CondResult Then { Sell(); }
프로필 이미지
하늘구름
2024-03-01
1070
글번호 177086
종목검색
답변완료

부탁드립니다.

1. 당일 콜의 현재 종가가 풋의 최고가 위로 올라가면 계속 빨강색으로, 다시 최고가 이하로 내려가면 계속 파란색으로, 당일 풋의 현재 종가가 콜의 최고가 위로 올라가면 계속 파란색으로, 다시 최고가 이하로 내려가면 계속 빨강색으로 구현해 주세요 2. 당일 콜의 현재 종가가 풋의 최저가 아래로 내려가면 계속 빨강색으로, 다시 최저가 이상으로 올라가면 계속 파란색으로, 당일 풋의 현재 종가가 콜의 최저가 아래로 내려가면 계속 파란색으로, 다시 최저가 이상으로 올라가면 계속 빨강색으로 구현해 주세요 3. 콜이든 풋이든 현재 종가가 당일 상대방 최고가 위로 올라갔다가 다시 최고가 아래로 내려오면 계속 파란색으로, 콜이든 풋이든 현재 종가가 당일 상대방 최저가 아래로 내려갔다가 다시 최저가 위로 올라오면 빨강색으로 계속 구현해 주세요 4. 전달 고가, 저가, 종가, 시가 및 당월 시가와 중간값을 우측 추세선으로 구현해 주세요 5. 전주 고가, 저가, 종가, 시가 및 당주 시가와 중간값을 우측 추세선으로 구현해 주세요 6. 전일 고가, 저가, 종가, 시가 및 당일 시가와 중간값을 우측 추세선으로 구현해 주세요 7. 종가가 양봉이면 고가를 기준으로 수평 우측 추세선으로 17개봉 동안만 계속 구현해 주세요, 종가가 음봉이면 저가를 기준으로 수평 우측 추세선으로 17개봉 동안만 계속 구현해 주세요 고맙습니다.
프로필 이미지
서태공
2024-03-03
843
글번호 177085
강조
답변완료

도와 주세요_이평선골드/데드신호 발생수식

아래수식을 편집하는 과정에 "골든 크로스와 데드 크로스 신호 계산"에서 연산자 앞뒤 두데이터 값이 같아야 된다는 요류가 뜹니다, 뭐가 잘못된건가요? 여기에서 GoldenCrossSignal_Small = CrossUp(SmallMA, MediumMA); DeadCrossSignal_Small = CrossDown(SmallMA, MediumMA); GoldenCrossSignal_Medium = CrossUp(MediumMA, LargeMA); DeadCrossSignal_Medium = CrossDown(MediumMA, LargeMA); GoldenCrossSignal_Large = CrossUp(SmallMA, LargeMA); DeadCrossSignal_Large = CrossDown(SmallMA, LargeMA); ======아래===== var : SmallMA(0), MediumMA(0), LargeMA(0); var : GoldenCrossSignal_Small(0), DeadCrossSignal_Small(0); var : GoldenCrossSignal_Medium(0), DeadCrossSignal_Medium(0); var : GoldenCrossSignal_Large(0), DeadCrossSignal_Large(0); var : tx(0); 골든 크로스와 데드 크로스 신호 계산 GoldenCrossSignal_Small = CrossUp(SmallMA, MediumMA); DeadCrossSignal_Small = CrossDown(SmallMA, MediumMA); GoldenCrossSignal_Medium = CrossUp(MediumMA, LargeMA); DeadCrossSignal_Medium = CrossDown(MediumMA, LargeMA); GoldenCrossSignal_Large = CrossUp(SmallMA, LargeMA); DeadCrossSignal_Large = CrossDown(SmallMA, LargeMA); 골든 크로스와 데드 크로스 신호 표시 if GoldenCrossSignal_Small then begin tx = Text_New_Self(sDate, stime, SmallMA, "▲"); Text_SetStyle(tx, 2, 0); Text_SetColor(tx, Red); end; if DeadCrossSignal_Small then begin tx = Text_New_Self(sDate, stime, SmallMA, "▼"); Text_SetStyle(tx, 2, 1); Text_SetColor(tx, Blue); end; if GoldenCrossSignal_Medium then begin tx = Text_New_Self(sDate, stime, MediumMA, "▲"); Text_SetStyle(tx, 2, 0); Text_SetColor(tx, Red); end; if DeadCrossSignal_Medium then begin tx = Text_New_Self(sDate, stime, MediumMA, "▼"); Text_SetStyle(tx, 2, 1); Text_SetColor(tx, Blue); end; if GoldenCrossSignal_Large then begin tx = Text_New_Self(sDate, stime, LargeMA, "▲"); Text_SetStyle(tx, 2, 0); Text_SetColor(tx, Red); end; if DeadCrossSignal_Large then begin tx = Text_New_Self(sDate, stime, LargeMA, "▼"); Text_SetStyle(tx, 2, 1); Text_SetColor(tx, Blue); end; end;
프로필 이미지
치어스카한
2024-03-01
923
글번호 177084
지표
답변완료

PercentRank 함수 만들어주세요

안녕하세요 어느덧 2월도 갑니다..항상 건강하십쇼 다름이 아니라 엑셀의 PercentRank 기능을 예스랭귀지에서 사용하고 싶은데 없어서 문의드립니다. https://support.microsoft.com/ko-kr/office/percentrank-%ED%95%A8%EC%88%98-f1b5836c-9619-4847-9fc9-080ec9024442 참고 부탁드립니다. *값은 변수가 아니라 Array로 저장시켜주세요. (어레이 저장 개수는 예트가 허락하는 한 가장 큰 값으로 부탁드려요) 사유 : variable이면 maxbarsback이 늘어남 PERCENTRANK(1) = Array로 저장되는 모든 값들이라는 범위에서 마지막 Array에 저장된 값의 백분율 순위 PERCENTRANK(2) = 전 봉의 PERCENTRANK(1) 예제에는 Close 값을 Array에 담아서 부탁드립니다. ex) Percentrank(Close) = 차트상 모든 C 값이라는 범위에서 마지막 저장된 C 값의 백분율 순위 밑에껀 정답은 아니지만 혹시 도움 될까봐서 올립니다. /////// /////// // PercentRank 함수 정의 function PercentRank(currentValue, DataArray) vars: vari1(0), numLower(numeric), // 현재 값보다 낮은 값의 개수 totalCount(numeric), // 총 값의 개수 rank(numeric); // 백분위 순위 vari1 = Close; if CurrentBar >= 1 Then { numLower = 0; totalCount = 0; For cnt = 100000 DownTo 1 { vv[cnt] = VV[cnt-1]; if vv[cnt] > 0 Then { if dataArray[value] < currentValue then numLower = numLower + 1; totalCount = totalCount+1 } } vv[0] = vari1 } // 백분위 순위 계산 rank = (numLower / totalCount) * 100; // 함수 결과 반환 PercentRank = rank; percentileRank = PercentRank(Close) /////// ///////
프로필 이미지
이만스닥
2024-02-29
876
글번호 177073
사용자 함수
답변완료

지표에 신호 교차시 화살표 신호 넣기

아래는 trix지표인데 TRIXv(0)와 TRIXsig(0)가 교차시 화살표 신호가 나오게 하려 합니다 -------------------------------------- Input : Period(12), sigPeriod(9); var : TRIXv(0),TRIXsig(0); TRIXv = TRIX(Period); TRIXsig = ema(TRIX(Period),sigPeriod); Plot1(TRIXv,"TRIX"); Plot2(TRIXsig,"TRIX시그널"); PlotBaseLine1(0,"기준선");
프로필 이미지
치어스카한
2024-02-29
871
글번호 177072
지표