커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4797
글번호 230811
답변완료
부탁드립니다.
아래 두수식에서 매도포지션이나 매수포지션을 선택해서 한쪽 방향으로만 매매하도록하려면 어떻게해야하는지 부탁드립니다.
늘 부족한 설명에도 잘 만들어 주셔서 정말 감사드립니다.
1. var : T(0),tx(0);
var1 = ma(c,1);
var2 = ma(C,900);
if var2[1]>var2[0] and
OPEN[0]>var1 and
OPEN[0]>CLOSE[0] Then
T = -1;
if var2[1]<var2[0] and
OPEN[0]<var1 and
OPEN[0]<CLOSE[0] Then
T = 1;
if MarketPosition == 0 and T == -1 and countif(T == T[1],3) == 3 Then{
sell();
Text_Delete(tx);
tx = Text_New(sdate,stime,H+PriceScale*2,"매도 : "+NumToStr(c,2));
}
if MarketPosition == 0 and T == 1 and countif(T == T[1],3) == 3 Then{
buy();
Text_Delete(tx);
tx = Text_New(sdate,stime,H+PriceScale*2,"매수 : "+NumToStr(c,2));
}
SetStopProfittarget(PriceScale*500,PointStop);
SetStopLoss(PriceScale*396,PointStop);
---------------------------------------------------------------------
2. var : T(0);
var1 = ma(c,60);
var2 = ma(C,18);
if var2[1]>var2[0] and
OPEN[0]>var1 and
OPEN[0]>CLOSE[0] Then
T = -1;
SELL();
if var2[1]<var2[0] and
OPEN[0]<var1 and
OPEN[0]<CLOSE[0] Then
T = 1;
if MarketPosition == 0 and T == -1 and countif(T == T[1],3) == 3 Then
sell();
if MarketPosition == 0 and T == 1 and countif(T == T[1],3) == 3 Then
buy();
SetStopProfittarget(PriceScale*1,PointStop);
SetStopLoss(PriceScale*30,PointStop);
2015-07-24
97
글번호 88851
답변완료
수식부탁드립니다
안녕하세요..
1)단순 20일선이 상승하면 하락하기전까지는 상승하는 지점의 저점에서부터 우측으로 빨간색을 표시하고,
이후
2)단순 20일선이 하락하면 상승하기전까지는 하락하는 지점의 고점에서부터 우측으로 청색선을
표시하고자 합니다.
수식부탁드립니다..
2015-07-24
104
글번호 88850
답변완료
검색식에서 알람기능을 추가 및 43255 답변에 대한 검토부탁합니다
1. macd 크로스 강세 국면일 때 세로선(수직선)을 빨강색으로 차팅하면서 알람 추가 하는 수식
macd 크로스 약세 국면일 때 세로선(수직선)을 파랑색으로 차팅하면서 알람 추가 하는 수식
2. 43255 질문에 대한 1번의 경우 속성변경에서 막대그래프를 지정해도 색상처리가 제대로 안되고 있습니다!!
- 검토바랍니다
감사합니다!!!
2015-07-24
118
글번호 88849
답변완료
부탁드립니다.
안녕하세요.
프로그램 초보라 몇번을 봐도 이해가 안되어서
아래코딩 설명 좀 부탁드립니다.
=================================================================
Input:length(12);
Var:j(0),lastHiVal(0),lastLoVal(0),turnPntBit(""),TL1(0);
var : UpTL_chk(false),DnTL_chk(false);
Array:valArr[20](0),barArr[20](0),turnPntArr[20](""); ## 어디에 사용하는 변수인지??
// 봉이 새로 생겼으므로 봉개수 관리하는 변수들의 봉개수 값 1씩 증가
For j = 0 To 19 { ## 왜 20개 이죠? 기간이 12인데?
barArr[j] = barArr[j] + 1;
}
// 고점조건 = 현재 봉의 고가가 기간최고가이면서 최고가 갱신되었을 때;
// 저점조건 = 현재 봉의 저가가 기간최저가이면서 최저가 갱신되었을 때;
// 고점,저점조건 만족시 현재 봉의 고[저]가를 변수에 저장
Condition1 = Highest(H,length) == H and lastHiVal <> H;
Condition2 = Lowest(L,length) == L and lastLoVal <> L;
If Condition1 Then lastHiVal = H;
If Condition2 Then lastLoVal = L;
// 전환점구분 null값으로 초기화;
// if 고점조건, 저점조건 동시 만족시 {
// if 전환점배열의 현재(배열상 1번째)값이 고점이면 전환점구분 = 저점;
// else if 전환점배열의 현재 값이 저점이면 전환점구분 = 고점;
// else if 고점조건 만족하면 전환점구분 = 고점;
// else if 저점조건 만족하면 전환점구분 = 저점;
turnPntBit = "";
If Condition1 and Condition2 Then {
If turnPntArr[1] == "Hi" Then turnPntBit = "Lo";
Else If turnPntArr[1] == "Lo" Then turnPntBit = "Hi";
}
Else If Condition1 Then turnPntBit = "Hi";
Else If Condition2 Then turnPntBit = "Lo";
// if 전환점구분에 값이 있을 때만 then 아래 실행, 없으면 통과
// if 신규 전환점구분이 현재(전환점배열 1번째)와 다르면 then
// 배열값들을 이전값으로 Move;
If turnPntBit == "Hi" or turnPntBit == "Lo" Then {
If turnPntBit <> turnPntArr[1] Then {
for j = 18 downto 1 { ## 왜 18개 이죠?
valArr[j+1] = valArr[j]; ## 어떤값들이 들어가는지요?
barArr[j+1] = barArr[j]; ## 어떤값들이 들어가는지요?
turnPntArr[j+1] = turnPntArr[j]; ## 여기에는 어떤값이 들어가는지요?
}
}
// if 전환점구분이 바뀌었거나 또는
// (전환점구분은 안바뀌었는데
// (이전 고점보다 높은 고점이 발생했거나 또는
// 이전 저점보다 낮은 저점이 발생했으면)) then
If turnPntBit <> turnPntArr[1] or ## turnPntArr[1]는 어떤 값을 의미하는지요?
(turnPntBit == turnPntArr[1] and
((turnPntBit == "Hi" and valArr[1] < H) or ## 어떤값이 들어 있는지요?
(turnPntBit == "Lo" and valArr[1] > L))) Then {
// 값 배열에는 고점 또는 저점을 대입;
// 봉개수 배열에는 0값 대입;
// 전환점 배열에 전환점구분값을 대입;
valArr[1] = IFF(turnPntBit == "Hi",H,L);
barArr[1] = 0;
turnPntArr[1] = turnPntBit; ## turnPntArr[1] 어떤값이 들어가 있는지 모르겠어요?
// if 이전봉대비 전환점구분이 바뀌었다면 추세선 새로 그리고;
// else 전환점구분이 안바뀌었으면 값만 바뀐거므로 추세선 연장;
If turnPntArr[1][1] <> turnPntArr[1][0] Then
##turnPntArr[1][1] 랑 turnPntArr[1][0] 이 뭔지 어떤값이 들어가 있는지 모르겠어요
TL1 = TL_New(sDate[barArr[2]],sTime[barArr[2]],valArr[2],sDate[barArr[1]],sTime[barArr[1]],valArr[1]);
Else
TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]);
}
## TL 추세선 그리는 함수인데..매뉴얼을 봐도 전혀 모르겠네여요..
}
TL_SetSize(TL1,4);
TL_SetColor(TL1,GREEN);
# 진입 체크
TL_SetSize(TL1,4);
TL_SetColor(TL1,GREEN);
If turnPntArr[1][1] <> turnPntArr[1][0] and turnPntArr[1][0] == "Lo" Then ## turnPntArr[1][1] 와 turnPntArr[1][0] 여기에는 어떤값이 들어가 있나요?
var1 = valArr[2]; ## valArr[2] 에는 어떤값이 들어가 있나요?
if turnPntArr[1][1] <> turnPntArr[1][0] and turnPntArr[1][0] == "Hi" Then
var2 = valArr[2];
# 매수진입
IF turnPntArr[1][0] == "Hi" and C > var1 then {
buy("buy") ;
}
# 매도진입
IF turnPntArr[1][0] == "Lo" and C < var2 then {
sell("sell") ;
}
# 매수청산
IF Marketposition == 1 and turnPntArr[1][1] <> turnPntArr[1][0] and turnPntArr[1][0] == "Lo" Then {
ExitLong("BX1");
}
# 매도청산
IF Marketposition == -1 and turnPntArr[1][1] <> turnPntArr[1][0] and turnPntArr[1][0] == "Hi" Then {
ExitShort("SX1");
}
##### 당일청산 #####
if stime == 050000 or (stime > 055000 and stime[1] < 050000) then { # 포지션 청산
exitlong("BDF");
exitshort("SDF");
}
전체적으로 글로 설명해 주시기 어렵겠지만 최대한 설명 좀 부탁드립니다.
그리고 ## 문의된 곳 집중적으로 설명 부탁드립니다.
번거롭게 해드려 죄송합니다.
감사합니다.
2015-07-24
108
글번호 88848
답변완료
부탁 드립니다.
운영자님~~!
수식 작성에 수고가 많으십니다.
그림과 같이(유로화)
지표 끝 부분에 수평선 2개(A,A1) 및
지표의 고점과 전전고점(B,B1,B2...) 을 연결 하는선
지표의 저점과 전전저점(C,C1,C2...) 을 연결 하는선을
부탁 드립니다.
미리 감사드리오며 경배 올립니다.
//수식1-주가 파동선//
Input:Period(48),Rsi변동폭(10);
Var:j(0),상승(100),하락(-100),양방향(2),추세(0),
파동선(0),Rsi파동선(0),방향(0),RsiV(0),추세선(0);
Array:고[20](0),저[20](0),고Bar[20](0),저Bar[20](0),
Rsi고[20](0),Rsi저[20](0),Rsi고Bar[20](0),Rsi저Bar[20](0);
RsiV = RSI(Period);
#==========================================#
# 전고점,전저점 index 증가
#==========================================#
For j = 1 To 19
{
Rsi고Bar[j] = Rsi고Bar[j] + 1;
Rsi저Bar[j] = Rsi저Bar[j] + 1;
저Bar[j] = 저Bar[j] + 1;
고Bar[j] = 고Bar[j] + 1;
}
#==========================================#
# 최근 고,저 갱신
#==========================================#
If Rsi고[0] <= RsiV || Rsi고[0] == 0 || IsNaN(Rsi고[0]) == True Then
{
Rsi고[0] = RsiV;
Rsi고Bar[0] = 0;
}
Else
Rsi고Bar[0] = Rsi고Bar[0] + 1;
If Rsi저[0] >= RsiV || Rsi저[0] == 0 || IsNaN(Rsi저[0]) == True Then
{
Rsi저[0] = RsiV;
Rsi저Bar[0] = 0;
}
Else
Rsi저Bar[0] = Rsi저Bar[0] + 1;
If 고[0] <= H || 고[0] == 0 || IsNaN(고[0]) == True Then
{
고[0] = H;
고Bar[0] = 0;
}
Else
고Bar[0] = 고Bar[0] + 1;
If 저[0] >= L || 저[0] == 0 || IsNaN(저[0]) == True Then
{
저[0] = L;
저Bar[0] = 0;
}
Else
저Bar[0] = 저Bar[0] + 1;
#==========================================#
# 추세방향 결정
#==========================================#
If Rsi저[0][1] + Rsi변동폭 > RsiV[1] &&
Rsi저[0][1] + Rsi변동폭 <= RsiV Then 방향 = 상승;
If Rsi고[0][1] - Rsi변동폭 < RsiV[1] &&
Rsi고[0][1] - Rsi변동폭 >= RsiV Then 방향 = 하락;
#==========================================#
# 추세변화에 따른 변곡점 처리
#==========================================#
If 방향[1] == 하락 && 방향 == 상승 Then
{
For j = 18 DownTo 1
{
Rsi저[j+1] = Rsi저[j];
Rsi저Bar[j+1] = Rsi저Bar[j];
저[j+1] = 저[j];
저Bar[j+1] = 저Bar[j];
}
Rsi저[1] = Rsi저[0];
Rsi저Bar[1] = Rsi저Bar[0];
Rsi파동선 = Rsi저[0];
Rsi저[0] = RsiV;
Rsi저Bar[0] = 0;
Rsi고[0] = RsiV;
Rsi고Bar[0] = 0;
저[1] = 저[0];
저Bar[1] = 저Bar[0];
파동선 = 저[0];
저[0] = L;
저Bar[0] = 0;
고[0] = H;
고Bar[0] = 0;
plot2(파동선,"2",blue);
}
Else If 방향[1] == 상승 && 방향 == 하락 Then
{
For j = 18 DownTo 1
{
Rsi고[j+1] = Rsi고[j];
Rsi고Bar[j+1] = Rsi고Bar[j];
고[j+1] = 고[j];
고Bar[j+1] = 고Bar[j];
}
Rsi고[1] = Rsi고[0];
Rsi고Bar[1] = Rsi고Bar[0];
Rsi파동선 = Rsi고[0];
Rsi고[0] = RsiV;
Rsi고Bar[0] = 0;
Rsi저[0] = RsiV;
Rsi저Bar[0] = 0;
고[1] = 고[0];
고Bar[1] = 고Bar[0];
파동선 = 고[0];
고[0] = H;
고Bar[0] = 0;
저[0] = L;
저Bar[0] = 0;
plot3(파동선,"2",magenta);
}
Else If 방향[1] == 하락 && 방향 == 하락 Then
{
If Rsi고[1] < Rsi고[0] &&
Rsi고[0][1] - Rsi변동폭 <= RsiV[1] &&
Rsi고[0][1] - Rsi변동폭 > RsiV Then
{
Rsi고[1] = Rsi고[0];
Rsi고Bar[1] = Rsi고Bar[0];
Rsi파동선 = Rsi고[0];
Rsi고[0] = RsiV;
Rsi고Bar[0] = 0;
}
If 고[1] < 고[0] &&
고[0] > H Then
{
고[1] = 고[0];
고Bar[1] = 고Bar[0];
파동선 = 고[0];
고[0] = H;
고Bar[0] = 0;
}
}
Else If 방향[1] == 상승 && 방향 == 상승 Then
{
If Rsi저[1] > Rsi저[0] &&
Rsi저[0][1] + Rsi변동폭 >= RsiV[1] &&
Rsi저[0][1] + Rsi변동폭 < RsiV Then
{
Rsi저[1] = Rsi저[0];
Rsi저Bar[1] = Rsi저Bar[0];
Rsi파동선 = Rsi저[0];
Rsi저[0] = RsiV;
Rsi저Bar[0] = 0;
}
If 저[1] > 저[0] &&
저[0] < L Then
{
저[1] = 저[0];
저Bar[1] = 저Bar[0];
파동선 = 저[0];
저[0] = L;
저Bar[0] = 0;
}
}
#==========================================#
# 지표식 출력
#==========================================#
If Rsi파동선[1] != Rsi파동선 Then
Plot1(파동선,"주가파동선"); //적당껏 수평이동
Else If LastBarOnChart == 1 Then {
plot1(Iff(방향 == 상승,고[0],저[0]));
if 방향 == 상승 Then
plot3(고[0],"2",magenta);
if 방향 == 하락 Then
plot2(저[0],"2",blue);
}
2015-07-24
260
글번호 88847
답변완료
질문드립니다
안녕하세요 오랜만에 글 남겨 봅니다
X봉(1분 5분 10분 등등)에서 시가보다 종가가 0.20 높을때 주황색으로 강조하라
또한 시가보다 종가가 0.20 낮을때는 녹색으로 강조하라
부탁 드립니다
2015-07-24
100
글번호 88846
답변완료
부탁드립니다.
이베스트에는 있는데 현대예스트레이드에는 없어서 부탁드립니다.
그림3과 같이 DMI강세구간, DMI약세구간을 현대예스트레이드 차트에 적용하고 싶습니다.
늘 부족한 설명에도 잘 만들어 주셔서 정말 감사합니다.
2015-07-24
158
글번호 88845
ysman 님에 의해서 삭제되었습니다.
2015-07-23
10
글번호 88844
답변완료
검색식 부탁드립니다.
안녕하세요.
검색수식 하나 부탁드립니다.
10, 20, 30 이평중에서 가장 큰값을 a 라 하고 가장 작은 값을 b라 한다면
현재봉이 양봉이고 a보다 크고 1개전봉부터 12개전봉까지의 10-6-6스토의 %k값의 최저값이 30이하이고
현재봉부터 12개봉전까지의 종가로 최저가가 현재봉부터 12개전봉까지의 b의 가장 작은값보다 작은 종목을 검색하는 수식 부탁드립니다.
2015-07-23
119
글번호 88842