커뮤니티
예스랭귀지 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 (최종);
2022-04-14
1429
글번호 158031
답변완료
부탁 드립니다~~
분봉 3분봉 이상에서
상승 후, 첫 조정 음봉의 시가를 돌파 하는 종목을 찾을 수 있을까요?
부탁 드립니다.
3분봉 또는 15분봉 사이
어느 분봉 이든~~
부탁 드립니다.
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하는 기능이 있는지요? 감사합니다
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