커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

문의 드립니다

안녕하세요, 사용자함수 문의 드립니다. 아래와 같은 "콜합",,,, 이라는 사용자함수를 만들었다고 했을때, 새로운 전략실행창 을 열어서 그 창에서는 DATA 불러오는것 없이 "콜합"을 이용한 지표는 못만드나요? (아래 예) 혹시 사용가능한 방법은 있는지요? ------사용자함수 -------------------- VAR : 콜360(0), 콜362.5(0), 콜합(0); 콜360 = data1(c); 콜362.5 = data2(c); 콜합 = 콜360 + 콜362.5 ; ------위의 사용자 함수 "콜합"을 이용한 지표---------------- VAR : 최종(0); 최종 = 콜합 + 2.5 ; PLOT1 (최종);
프로필 이미지
kimfeel
2022-04-14
1429
글번호 158031
사용자 함수
답변완료

부탁 드립니다~~

분봉 3분봉 이상에서 상승 후, 첫 조정 음봉의 시가를 돌파 하는 종목을 찾을 수 있을까요? 부탁 드립니다. 3분봉 또는 15분봉 사이 어느 분봉 이든~~ 부탁 드립니다.
프로필 이미지
hg950265
2022-04-14
1372
글번호 158023
종목검색
답변완료

문의드립니다

재문의/ 아래와 같이 문의드렸으나 답변이 어렵다 하시어 다시 문의드립니다. 아래 수식에는 손절 규칙이 없어 수많은 큰 변동성 장에서 나타나는 큰 금액의 손실을 예방하고자 손절을 하고 싶습니다. 아래 수식에 손절이 가능하도록 손절 틱수(예, 매수 및 매도에서 +50틱, -50틱 초과시 손절)를 지정할 수 있게 수정 부탁해요. 답변/ 안녕하세요 예스스탁입니다. 문의하신 내용까지는 저희가 답변해 드리기 어렵습니다. 도움을 드리지 못해 죄송합니다. 즐거운 하루되세요 > 복둥이 님이 쓴 글입니다. > 제목 : 문의드립니다 > 1. 아래 수식에서 추세선 꼭지점 마다 추세가 전환될 경우를 예상하여/ 추세 전환 후 첫 진입하려고 하는 첫진입 예상지수 (전고점+N틱, 혹은 전저점-N틱)를 알기 쉽게 추세 꼭지점 위,아래에 표시되게 수정 부탁합니다. 2. 현재 추세가 반대로 바뀌면 이미 진입된 매수, 매도 물량이 일괄 청산되도록 되어 있는데/ 추세가 바뀔 때 바로 청산되는 것이 아니라 이미 진입된 매수 물량은 마지막 전고점+N틱에 청산되고, 매도 물량은 전저점-N틱에 청산될 수 있도록 수정 부탁해요. 감사합니다. Input:length(12); Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),TL2(0),TL3(0),Text1(0),처리구분(""),TL_Val1(0),TL_Val2(0),color(0); var:T(0),B(0),Bx(0),S(0),Sx(0); Array:고점[10,2](0),저점[10,2](0); 처리구분 = ""; If Highest(H,length) == H and lastHiVal <> H and Lowest(L,length) == L and lastLoVal <> L Then { If 저점[1,1] > L Then 처리구분 = "저점처리"; If 고점[1,1] < H Then 처리구분 = "고점처리"; } Else If Highest(H,length) == H and lastHiVal <> H Then 처리구분 = "고점처리"; Else If Lowest(L,length) == L and lastLoVal <> L Then 처리구분 = "저점처리"; If 처리구분 == "고점처리" Then { T = 1; lastHiVal = H; If 고점[1,2] < 저점[1,2] Then { For j = 10 DownTo 2 { 고점[j,1] = 고점[j-1,1]; 고점[j,2] = 고점[j-1,2]; } } If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then { 고점[1,1] = H; 고점[1,2] = Index; sBar = Index - 저점[1,2]; eBar = 0; If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then { TL_Delete(TL1); Text_Delete(Text1); If 고점[3,1][1] < 고점[2,1][1] and 고점[2,1][1] > 고점[1,1][1] and 저점[2,1][1] < 저점[1,1][1] Then TL_Delete(TL2); } if 고점[1,1] > 고점[2,1] or 고점[2,1] == 0 Then{ color = RED; # buy("b"); } TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]); TL_SetColor(TL1,color); Text1 = Text_New(sDate[eBar],sTime[eBar],고점[1,1],NumToStr(abs(고점[1,1]-저점[1,1])/PriceScale,0)+NewLine+NumToStr(고점[1,1],2)); Text_SetStyle(Text1, 2, 1); If 고점[3,1] < 고점[2,1] and 고점[2,1] > 고점[1,1] and 저점[2,1] < 저점[1,1] Then { sBar = Index - 저점[2,2]; eBar = Index - 저점[1,2]; } } } If 처리구분 == "저점처리" Then { T = -1; lastLoVal = L; If 저점[1,2] < 고점[1,2] Then { For j = 10 DownTo 2 { 저점[j,1] = 저점[j-1,1]; 저점[j,2] = 저점[j-1,2]; } } If 저점[1,2] < 고점[1,2] or 저점[1,1] > L Then { 저점[1,1] = L; 저점[1,2] = Index; sBar = Index - 고점[1,2]; eBar = 0; If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then { TL_Delete(TL1); Text_Delete(Text1); If 저점[2,1][1] < 저점[1,1][1] and 저점[2,1][1] < 저점[3,1][1] and 고점[2,1][1] > 고점[1,1][1] Then TL_Delete(TL3); } if 저점[1,1] < 저점[2,1] or 저점[2,1] == 0 Then{ color = blue; # sell("s"); } TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]); TL_SetColor(TL1,color); Text1 = Text_New(sDate[eBar],sTime[eBar],저점[1,1],NumToStr(abs(고점[1,1]-저점[1,1])/PriceScale,0)+NewLine+NumToStr(저점[1,1],2)); Text_SetStyle(Text1, 2, 0); If 저점[2,1] < 저점[1,1] and 저점[2,1] < 저점[3,1] and 고점[2,1] > 고점[1,1] Then { sBar = Index - 고점[2,2]; eBar = Index - 고점[1,2]; } } } TL_SetSize(TL1,3); : 첫진입(),추가진입(); #상승구간의 마지막저점 저장 if Color == RED Then { var1 = 저점[2,1]; } #하락구간의 마지막 고점 저장 if Color == BLUE Then { var2 = 고점[2,1]; } if MarketPosition <= 0 Then { if color == BLUE and var1 > 0 and L > var1-PriceScale* Then Buy("b",AtLimit,var1-PriceScale*,1); } if MarketPosition == 1 Then { value1 = Floor(MaxEntries/N)+1; Buy("bb",AtLimit,(var1[BarsSinceEntry]-PriceScale*)-(PriceScale*)*MaxEntries,value1); if T == -1 and 고점[1,1] > 0 Then ExitLong("bx1",AtLimit,고점[1,1]+PriceScale*1); if T == 1 and 고점[2,1] > 0 Then ExitLong("bx2",AtLimit,고점[2,1]+PriceScale*1); } if MarketPosition >= 0 Then { if Color == RED and Var2 > 0 and H < var2+PriceScale* Then Sell("s",AtLimit,Var2+PriceScale*,1); } if MarketPosition == -1 Then { value1 = Floor(MaxEntries/N)+1; Sell("ss",AtLimit,(var2[BarsSinceEntry]+PriceScale*)+(PriceScale*)*MaxEntries,value1); if T == 1 and 저점[1,1] > 0 Then ExitShort("sx1",AtLimit,저점[1,1]-PriceScale*1); if T == -1 and 저점[2,1] > 0 Then ExitShort("sx2",AtLimit,저점[2,1]-PriceScale*1); }
프로필 이미지
복둥이
2022-04-14
1102
글번호 158021
시스템
답변완료

문자열 수정

안녕하세요 특정 문자를 파이썬으로 치면 replace하는 기능이 있는지요? 감사합니다
프로필 이미지
nirvana
2022-04-14
1464
글번호 158020
지표
답변완료

타주기 지표 함수화

타주기의 볼린저밴드 지표식을 보고 이를 함수화하려하는데 지표식과 똑같이 쓰고 함수 이름만 bbdn, bbup로 하면 될까요? 아래는 bbdn함수식입니다 문의를 드리는 이유는 뭔가 시스템식에 적용했을때 다른 것 같아서 그럽니다 input : 타주기분(NumericSimple),P(NumericSimple),Dv(NumericSimple); var : S1(0),D1(0),TM(0),TF(0); var : cnt(0),SumSqrt(0),Stdv(0); var : sum(0),BBmd(0),Bbup(0); Array : CC[100](0); if Bdate != Bdate[1] Then{ S1 = TimeToMinutes(stime); D1 = sdate; } if D1 > 0 then{ if sdate == D1 Then TM = TimeToMinutes(stime)-S1; Else TM = TimeToMinutes(stime)+1440-S1; TF = TM%타주기분; if Bdate != Bdate[1] or (Bdate == Bdate[1] and 타주기분 > 1 and TF < TF[1]) or (Bdate == Bdate[1] and 타주기분 > 1 and TM >= TM[1]+타주기분) or (Bdate == Bdate[1] and 타주기분 == 1 and TM > TM[1]) Then { for cnt = 1 to 99 { CC[cnt] = CC[cnt-1][1]; } } CC[0] = C; if CC[P] > 0 then{ sum = 0; for cnt = 0 to P-1{ sum = sum + CC[cnt]; } BBmd = sum/P; SumSqrt = 0; For cnt = 0 To P - 1 { SumSqrt = SumSqrt + (CC[cnt] - BBmd)^2; } Stdv = SquareRoot(SumSqrt / P); BBup = BBmd + (Dv * Stdv); BBdn = BBmd - (Dv * Stdv); } }
프로필 이미지
초심자의행운
2022-04-13
1696
글번호 158019
사용자 함수
답변완료

지표식 문의 드립니다.

1분봉 차트에 2개 라인을 그리고 싶은데 문의 드립니다. 1. 1분봉 저가대비 5%라인.. 1분봉 캔들 저가*1.05 금액을 이어서 그려진 라인 조건1 : 전봉의 저가*1.05 와 현재봉 저가*1.05 을 비교해서 낮은쪽으로 선택 조건2 : 봉의 고가가 저가대비 5%라인을 넘어가면 조건1 비교해서 낮은쪽 선택이 아니라 현재봉의 저가*1.05 2. 1분봉 고가대비 -10% 라인 1분봉 캔들 고가*0.9 금액을 이어서 그려진 라인 조건1 : 전봉의 고가*0.90 와 현재봉 고가*0.90 을 비교해서 높은쪽으로 선택 조건2 : 봉의 고가가 저가대비 5%라인을 넘어가면 조건1 비교해서 높은쪽 선택이 아니라 현재봉의 고가*0.90
프로필 이미지
맴맴잉
2022-04-14
1514
글번호 158018
지표
답변완료

지표식 요청 드립니다.(이평)

* 매번 도움에 고맙습니다. * 아래 기준 수평선 좀 요청 드립니다. var11 = ma(c,5) ; Var12 = ma(c,20) ; Condition1 = CrossUp(VAR1,Var2); ## 크로스업 한 봉기준 그다음 Condition1 == true 봉을 기준으로 이전 100봉 최저가(var13 = Lowest(L,100);)을 구하고 아래 수평선 표시 좀 부탁 드립니다. ## 수평선 예시 var : TL(0),TX(0); TL_Delete(TL); TL = TL_New(sDate[100],sTime[100],Var13,sDate,sTime,Var13); Text_Delete(TX); TX = Text_New(sDate,sTime,Var13,NumToStr(Var13,2)); * 고맙습니다. 수고하십시요.
프로필 이미지
요타
2022-04-14
1503
글번호 158017
지표
답변완료

최고가 검색

안녕하세요.. 일봉이 100개이상인 종목에서.. 특정봉(50일)이전 까지의 최고가를 구하려면 어떻게 해야 하나요?
프로필 이미지
디딤돌
2022-04-14
1440
글번호 158016
검색
답변완료

문의드립니다

다음식은 N일의 피봇과 지지저항을 구하는 식인데요 N일 지정대신 특정일이후의 피봇/지지저항을 구하는 식으로 변형 부탁드립니다 기본식의 개념은 똑같게 하되.. n일 대신 특정일이후로.. 감사합니다 input : P(6); Var : value(0),sum1(0),sum2(0),sum3(0),maC(0),maH(0),maL(0),cnt(0); sum1 = 0; sum2 = 0; sum3 = 0; for cnt = 1 to P{ sum1 = sum1+DayClose(cnt); sum2 = sum2+DayHigh(cnt); sum3 = sum3+DayLow(cnt); } maC = sum1/P; # 전 6일간 평균종가 maH = sum2/P; # 전 6일간 평균고가 maL = sum3/P; # 전 6일간 평균저가 value = (maH+MaL+maC)/3; Plot1(value, "피봇포인트"); Plot2(2*value-maL, "1차저항"); Plot3(value+maH-maL, "2차저항"); Plot4(maH+2*(value-maL), "3차저항"); Plot5(2*value-maH, "1차지지"); Plot6(value-maH+maL, "2차지지"); plot7(mal-2*(maH-value),"3차지지");
프로필 이미지
러블리
2022-04-13
1635
글번호 158014
지표