커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

항셍관련지표문의

안녕하세요 관리자님! 나른한 봄날에도 환절기건강관리 잘하시길 바랍니다 다름이아니라 항셍관련 지표문의드리는데요 항셍은 시가발생시 갭이많이 나오는데요 오늘시가: 요일별 한국시각 오전 10시15분 발생하는시가 전일종가: 요일별 한국시각 새벽 02시에 끊나는 종가 각 요일별 (전일종가-오늘시가)의 10년치 평균값과 표준편차, 2*표준편차를 구하고 이를 지표로 표현하고싶습니다(차트서비스상 10년치가 계산안된다는거는 알고있습니다 저번처럼 기간설정할수있도록 부탁드립니다) 도와주십시요
프로필 이미지
카카
2019-04-17
240
글번호 127933
지표
답변완료

크로스에서 수직선 발생

안녕하세요. 항상 감사합니다. 20선과 60선의 크로스에서 선의 발생했으면 합니다. 골든크로스인 경우는 빨강색, 데드 크로스인 경우는 파란색으로 발생했으면 합니다. 그리고 수직선 발생 개수도 정할 수 있으면 합니다. 빨강색 2개, 파란색 2개 이런식으로 화면에 개수를 정할 수 있으면 합니다. 참고로 이미지 첨부해 봅니다.
프로필 이미지
타잔94
2019-04-17
288
글번호 127932
지표
답변완료

수식문의드립니다.

Input:chngRate(0.1); Var:j(0),lastHiVal(0),lastLoVal(0),turnPntBit(""),TL1(0); Array:valArr[10](0),barArr[10](0),turnPntArr[10](""); For j = 0 To 9 { barArr[j] = barArr[j] + 1; } Condition1 = Min(valArr[1],valArr[2]) * (1 + (chngRate/100)) < H and lastHiVal < H; Condition2 = Max(valArr[1],valArr[2]) * (1 - (chngRate/100)) > L and (lastLoVal > L || lastLoVal == 0); If Condition1 Then { lastHiVal = H; lastLoVal = 0; } If Condition2 Then { lastLoVal = L; lastHiVal = 0; } turnPntBit = ""; If Condition1 and Condition2 Then { If Max(valArr[1],valArr[2]) < H and Min(valArr[1],valArr[2]) > L Then turnPntBit = "HiLo"; Else If Max(valArr[1],valArr[2]) < H Then turnPntBit = "Hi"; Else If Min(valArr[1],valArr[2]) > L Then turnPntBit = "Lo"; } Else If Condition1 Then turnPntBit = "Hi"; Else If Condition2 Then turnPntBit = "Lo"; If turnPntBit <> "" Then { If turnPntBit == "HiLo" Then { valArr[1] = IFF(turnPntArr[1] == "Hi",H,L); barArr[1] = 0; TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]); If turnPntArr[1] == "Hi" Then turnPntBit = "Lo"; Else turnPntBit = "Hi"; } If turnPntBit <> turnPntArr[1] Then { for j = 8 downto 1 { valArr[j+1] = valArr[j]; barArr[j+1] = barArr[j]; turnPntArr[j+1] = turnPntArr[j]; } } If turnPntBit <> turnPntArr[1] or (turnPntBit == turnPntArr[1] and ((turnPntBit == "Hi" and valArr[1] < H) or (turnPntBit == "Lo" and valArr[1] > L))) Then { valArr[1] = IFF(turnPntBit == "Hi",H,L); barArr[1] = 0; turnPntArr[1] = turnPntBit; If turnPntArr[1][1] <> turnPntArr[1][0] Then{ TL1 = TL_New(sDate[barArr[2]],sTime[barArr[2]],valArr[2],sDate[barArr[1]],sTime[barArr[1]],valArr[1]); if turnPntArr[1][0]=="Hi" Then{ Sell(); } if turnPntArr[1][0] =="Lo" Then{ Buy(); } } Else TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]); } } TL_SetSize(TL1,1); TL_SetColor(TL1,GRAY); ---------------------------------------------------------------------------------- 안녕하세요. 위 수식처럼 차트에 추세선을 그리고 싶습니다.. 지표로 사용하고 싶은데.. 수정이나 쓸만한 수식 좀 부탁드립니다.
프로필 이미지
율담
2019-04-17
222
글번호 127931
사용자 함수
답변완료

종목검색식 작성부탁드립니다

조건1. 당일 5% 이상 상승한 양봉 종목 조건2. 당일 거래량이 10일 거래량이동평균선의 3배 이상 조건3. 당일 매수체결강도가 150% 이상 3가지 조건을 동시에 만족하는 종목검색식 작성부탁드립니다.
프로필 이미지
파워
2019-04-17
239
글번호 127930
종목검색
답변완료

수식변환부탁합니다.

안녕하세요. 1.해선용 타주기 분봉볼린져 입니다. 그런데 항셍용으로 쓰면 맞지가 않네요. 항셍 시간봉이 15분완성봉이어서 그런거 같은데 항셍에 맞게 타주기 분봉볼린져 수정바랍니다.60분 볼린져를 3분에 사용합니다 2.타주기 일봉인데 이것도 항셍에 맞게 수정부탁합니다. 3.타주기 분봉 60분봉 5,20이평을 3분에 사용하는 수식도(항셍에 맞게) 부탁합니다. 4.각60분봉의 시고저종을 3분에 나타내는 수식인데 이것도 항셍에 맞게 부탁합니다. 너무 많은것 같아 죄송합니다. 1.input : Ntime(60),P(20),Dv(2); var : cnt(0),count(0),sum(0),MiBBup(0),MiBBdn(0),Avgv(0),SumSqrt(0),Counter(0),Stdv(0); Array : CC[120](0); var1 = TimeToMinutes(stime)%Ntime; if dayindex() == 0 or (var1 < var1[1] and stime > stime[1]) Then{ for cnt = 1 to P-1{ CC[cnt] = CC[cnt-1][1]; } } CC[0] = C; If CC[P-1] > 0 Then{ sum = 0; for count = 0 to P-1{ sum = sum+CC[count]; } Avgv = sum/P; SumSqrt = 0; For Counter = 0 To P - 1 { SumSqrt = SumSqrt + (CC[Counter] - Avgv) * (CC[Counter] - Avgv); } Stdv = SquareRoot(SumSqrt / P); MiBBup = Avgv + (Dv * Stdv); MiBBdn = Avgv - (Dv * Stdv); plot1(MiBBup); plot2(Avgv); plot3(MiBBdn); } 2.input:p1(5), p2(20); var:j(0), cnt(0), sum1(0), sum2(0), ma1(0), ma2(0); sum1 = 0; sum2 = 0; for j = 0 to p2-1 { if j <= p1 - 1 then { sum1 = sum1 + dayclose(j); } if j <= p2 - 1 then { sum2 = sum2 + dayclose(j); } } ma1 = sum1 / p1; ma2 = sum2 / p2; plot1(ma1); plot2(ma2); 4.input : Mn(60),N(0); var : TF(0),cnt(0); Array : Ov[20](0),Hv[20](0),Lv[20](0),Cv[20](0); TF = TimeToMinutes(stime)%Mn; if dayindex == 0 or (stime > stime[1] and TF < TF[1]) Then{ Ov[0] = O; Hv[0] = H; Lv[0] = L; for cnt = 1 to 19{ Ov[cnt] = Ov[cnt-1][1]; Hv[cnt] = Hv[cnt-1][1]; Lv[cnt] = Lv[cnt-1][1]; Cv[cnt] = Cv[cnt-1][1]; } } if H > Hv[0] Then Hv[0] = H; if L < Lv[0] Then Lv[0] = L; Cv[0] = C; plot1(Ov[N],"N분봉시가"); plot2(Hv[N],"N분봉고가"); plot3(Lv[N],"N분봉저가"); plot4(Cv[N],"N분봉종가");
프로필 이미지
바닥차기
2019-04-18
285
글번호 127929
지표
답변완료

완전 초보 입니다. 모든 코스피 종목을 가져오는 검색식은요??

안녕하세요. 완전 초보입니다. 모든 코스피 종목 검색식(?)은 어떻게 해야 하는지요?? 그러니깐, 특별한 조건이 없습니다. 굳이 조건이라고 한다면 모든 코스피 종목입니다. 그리고, 이 검색식은 어디에 작성을 해야 하는지요?? 아무리 둘러보아도 예스트레이더, 에스랭귀지, 예스스팟 등의 용어가 모호하여 너무 헷갈립니다. 부디 초보때를 생각해서라도 도움부탁드립니다.
프로필 이미지
왕경태
2019-04-17
228
글번호 127928
검색
답변완료

부탁 드립니다

예를 들어 이동평균선 20일선을 지지하는 종목을 찾을 수 있을까요? 감사합니다
프로필 이미지
그대와함께
2019-04-17
236
글번호 127926
종목검색
답변완료

수식에서 글자크기를 조정할려면(큰것을 중간크기로)

시스템에서 ===>
프로필 이미지
정밀타격수
2019-04-19
245
글번호 127925
시스템
답변완료

부탁드립니다!

안녕하세요!! 1, 아래수식에서는 "검은색 세로선"이 나오는데 이선만 삭제해주시면 감사하겠습니다 2, 옵션 "특정 행사가"의 "콜가격과 풋가격을 합친 가격"으로 이평선을 나타내고싶습니다 예를들면 "행사가 290의 콜가격"과 "같은 행사가인 290의 풋의 가격"을 "합친가격"의 실시간 흐름을 이평선으로 보고자함입니다 여기에 이 이평선의 최고저점 자리에서는 각각 가로선이 나왔으면하구요 이 지점이 갱신되면 이 가로선도 같이 갱신되도록 부탁드립니다 감사합니다 ^^ ------------------------------------------------------------------------------------ input : af(0.02), maxAF(0.2); input : 텍스트출력(1),선굵기(2); var : T(0),cnt(0),count(0); var : HH1(0),LL1(0),HD1(0),HT1(0),LD1(0),LT1(0),day1(0),day0(0),TL3(0); var : TL1(0),TL2(0),tx1(0),tx2(0),tx11(0),tx22(0),idx(0),tx99(0),tx88(0); Array : HD[20](0),HT[20](0),HH[20](0),LD[20](0),LT[20](0),LL[20](0); Array : HI[20](0),LI[20](0); var1 = CSar(af,maxAF); if bdate != bdate[1] Then { day0 = sdate; day1 = day0[1]; } if crossup(c,var1) Then { T = 1; HH[0] = H; HD[0] = sdate; HT[0] = stime; HI[0] = index; for cnt = 1 to 19 { HD[cnt] = HD[cnt-1][1]; HT[cnt] = HT[cnt-1][1]; HH[cnt] = HH[cnt-1][1]; HI[cnt] = HI[cnt-1][1]; } if LL[0] > 0 Then { if 텍스트출력 == 1 then { Tx11 = Text_New(HD[1],HT[1],HH[1],NumToStr((HH[1]-LL[1])/PriceScale,0)+NewLine+NumToStr(HH[1],2)); Text_SetStyle(tx11,2,1); Text_SetColor(tx11,BLUE); Text_Delete(tx1); Tx1 = Text_New(HD[0],HT[0],HH[0],NumToStr((HH[0]-LL[0])/PriceScale,0)+NewLine+NumToStr(HH[0],2)); Text_SetStyle(tx1,2,1); Text_SetColor(tx1,GRAY); Condition1 = false; for cnt = 1 to 19 { if Condition1 == false and abs(LL[0]-LL[cnt]) <= PriceScale*1 and LD[cnt] >= day1 Then { Condition1 = true; TL1 = TL_New(LD[cnt],LT[cnt],LL[cnt],LD[0],LT[0],LL[0]); TL_SetSize(TL1,선굵기); TL_SetColor(TL1,CYAN); idx = abs(LI[0]-LI[cnt]); tx99 = Text_New(LD[0],LT[0],LL[0],NumToStr(idx,0)); Text_SetColor(tx99,CYAN); Text_SetStyle(tx99,0,2); Text_SetBold(tx99,1); } } TL_New(sdate,stime,99999999,sdate,stime,0); } } } if CrossDown(c,var1) Then { T = -1; LL[0] = L; LD[0] = sdate; LT[0] = stime; LI[0] = index; for cnt = 1 to 19 { LD[cnt] = LD[cnt-1][1]; LT[cnt] = LT[cnt-1][1]; LL[cnt] = LL[cnt-1][1]; LI[cnt] = LI[cnt-1][1]; } if HH[0] > 0 Then { if 텍스트출력 == 1 then { Tx22 = Text_New(LD[1],LT[1],LL[1],NumToStr((HH[1]-LL[1])/PriceScale,0)+NewLine+NumToStr(LL[1],2)); Text_SetStyle(tx22,2,0); Text_SetColor(tx22,RED); Text_Delete(tx2); Tx2 = Text_New(LD[0],LT[0],LL[0],NumToStr((HH[0]-LL[0])/PriceScale,0)+NewLine+NumToStr(LL[0],2)); Text_SetStyle(tx2,2,0); Text_SetColor(tx2,MAGENTA); Condition2 = false; for cnt = 1 to 19 { if Condition2 == false and abs(HH[0]-HH[cnt]) <= PriceScale*1 and HD[cnt] >= day1 Then { Condition2 = true; TL2 = TL_New(HD[cnt],HT[cnt],HH[cnt],HD[0],HT[0],HH[0]); TL_SetSize(TL2,선굵기); TL_SetColor(TL2,yellow); idx = abs(HI[0]-HI[cnt]); tx99 = Text_New(HD[0],HT[0],HH[0],NumToStr(idx,0)); Text_SetColor(tx99,CYAN); Text_SetStyle(tx99,0,2); Text_SetBold(tx99,1); } } } } } if T == 1 then { if H > HH[0] Then { HH[0] = H; HD[0] = sdate; HT[0] = stime; if 텍스트출력 == 1 then { Text_Delete(tx1); Tx1 = Text_New(HD[0],HT[0],HH[0],NumToStr((HH[0]-LL[0])/PriceScale,0)+NewLine+NumToStr(HH[0],2)); Text_SetStyle(tx1,2,1); Text_SetColor(tx1,black); TL_Delete(TL3); Text_Delete(tx88); Condition3 = false; for cnt = 1 to 19 { if Condition3 == false and abs(HH[0]-HH[cnt]) <= PriceScale*1 and HD[cnt] >= day1 Then { Condition3 = true; TL3 = TL_New(HD[cnt],HT[cnt],HH[cnt],HD[0],HT[0],HH[0]); TL_SetSize(TL3,선굵기); TL_SetColor(TL3,yellow); idx = abs(HI[0]-HI[cnt]); tx88 = Text_New(HD[0],HT[0],HH[0],NumToStr(idx,0)); Text_SetColor(tx88,CYAN); Text_SetStyle(tx88,0,2); Text_SetBold(tx88,1); PlaySound("C:₩예스트레이더₩data₩Sound₩alert.wav"); } } } } } if T == -1 then { if L < LL[0] Then { LL[0] = L; LD[0] = sdate; LT[0] = stime; if 텍스트출력 == 1 then { Text_Delete(tx2); Tx2 = Text_New(LD[0],LT[0],LL[0],NumToStr((HH[0]-LL[0])/PriceScale,0)+NewLine+NumToStr(LL[0],2)); Text_SetStyle(tx2,2,0); Text_SetColor(tx2,red); TL_Delete(TL3); Condition3 = false; for cnt = 1 to 19 { if Condition3 == false and abs(LL[0]-LL[cnt]) <= PriceScale*1 and LD[cnt] >= day1 Then { Condition3 = true; TL3 = TL_New(LD[cnt],LT[cnt],LL[cnt],LD[0],LT[0],LL[0]); TL_SetSize(TL3,선굵기); TL_SetColor(TL3,yellow); idx = abs(LI[0]-LI[cnt]); tx88 = Text_New(LD[0],LT[0],LL[0],NumToStr(idx,0)); Text_SetColor(tx88,CYAN); Text_SetStyle(tx88,0,2); Text_SetBold(tx88,1); PlaySound("C:₩예스트레이더₩data₩Sound₩alert.wav"); } } } } }
프로필 이미지
유로파54
2019-04-18
241
글번호 127921
지표