커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
3456
글번호 230811
답변완료
문의
적용
일반적으로 적용할때
마우스로 드래그 하면되는데
적용 이름은 불러왔는데
표시도없고 선도 없어서
챠트에 마우스 드래그 말고
다른 방법으로 챠트안에
적용 될수 있는 방법 알려주세요
2020-03-05
376
글번호 136592
답변완료
지표
색상넣어주세요.문법에 맞게 알려주세요
*************************************************************************************
색상추가식해봤읍니다.
input : ndate(20200302),색상1(YELLOW),색상2(GREEN);
if sdate == ndate Then
{
var1 = (DayHigh+daylow)/2;
var2 = (DayOpen+DayClose)/2;
}
if var1 > 0 and var2 > 0 Then
{
plot1(var1,색상1);이부분 에러
plot2(var2,색상2);이부분 에러
}
틀려요
**********************************************************************************
1-1(시고저종합)
input : ndate(20200302);
if sdate == ndate Then
{
var1 = (DayHigh+daylow)/2;
var2 = (DayOpen+DayClose)/2;
}
if var1 > 0 and var2 > 0 Then
{
plot1(var1);
plot2(var2);
}
2
var1 = (H+L)/2;
var2 = (O+c)/2;
var3 = (H[1]+L[1])/2;
var4 = (O[1]+c[1])/2;
var5 = (var1+var3)/2;
plot1(var1);
plot2(var2);
if var3 > 0 and var4 > 0 then
{
plot3(var3);
plot4(var4);
plot5(var5);
}
3
input : ndate1(20200302),ndate2(20200303);
if sdate == ndate1 Then
{
var1 = (DayHigh+daylow)/2;
var2 = (DayOpen+DayClose)/2;
}
if sdate == ndate2 Then
{
var3 = (DayHigh+daylow)/2;
var4 = (DayOpen+DayClose)/2;
}
if var1 > 0 and var2 > 0 then
{
plot1(var1);
plot2(var2);
}
if var3 > 0 and var4 > 0 then
{
plot3(var3);
plot4(var4);
}
if var1 > 0 and var3 > 0 Then
{
value1 = (var1+var3)/2;
plot5(value1);
}
4
var1 = (H+L)/2;
var2 = (O+c)/2;
var3 = (H[100]+L[100])/2;
var4 = (O[100]+c[100])/2;
var5 = (var1+var3)/2;
plot1(var1);
plot2(var2);
if var3 > 0 and var4 > 0 then
{
plot3(var3);
plot4(var4);
plot5(var5);
}
2020-03-05
399
글번호 136591
답변완료
문의드립니다
if C >= dayopen+PriceScale*1 Then
PlotPaintBar(H,L,"강조",MAGENTA);
if C <= dayopen-PriceScale*1 Then
PlotPaintBar(H,L,"강조",GREEN);
위수식에서 당일시가로부터고저중심갑 강조식을 부탁드립니다~~미리감사드립니다
2020-03-05
436
글번호 136590
답변완료
문의드립니다.
value1이 3봉이상 상승중이고
macd가 3봉이상 상승중이며
10일 이평이 상승중이면 매수
부탁드립니다.
2020-03-04
467
글번호 136589
답변완료
질문입니다.
아래 수식을 보면
틱차트에 1분봉 표시해도 안되는데 1분봉 표시 되게 할 수 없을까요?
1분봉 이상을 하면 잘나오는데
1분봉 잘 안됩니다. 1분봉 표시 하게 해주면 더 좋겠습니다.
감사합니다.
input : 분(3);
var : S1(0),D1(0),TM(0),TF(0),cnt(0);
Array : OO[50](0),HH[50](0),LL[50](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 = TimeToMinutes(stime)%분;
if bdate != Bdate[1] or (Bdate == Bdate[1] and TF < TF[1]) or stime == 154500 Then{
OO[0] = O;
HH[0] = H;
LL[0] = L;
for cnt = 1 to 49{
OO[cnt] = OO[cnt-1][1];
HH[cnt] = HH[cnt-1][1];
LL[cnt] = LL[cnt-1][1];
}
}
if OO[0] > 0 then
if H > HH[0] Then
HH[0] = H;
if L < LL[0] Then
LL[0] = L;
plot1(OO[0]);
plot2(HH[0]);
plot3(LL[0]);
}
2020-03-05
499
글번호 136588
달무드 님에 의해서 삭제되었습니다.
2020-03-04
0
글번호 136587
답변완료
수식 문의 드립니다.
수고하십니다.
1. 거래량이 분봉으로 2000건이상 일땐 스톡케스틱의 매수신호 일때 1계약 매수, 매도신호 발생시 청산하고, 매도 진입 를 사용하고
. 거래량이 분봉으로 2001 ~ 3000건 이상땐 파라볼릭 매수신호 일때 1계약 매수, 매도신호 발생시 청산하고, 매도 진입 를 사용..
거래량이 분봉으로 0건 ~1999 건 까진 MACD 매수신호 일때 1계약 매수, 매도신호 발생시 청산하고, 매도 진입 사용 하고 싶습니다.
수고하세요.
2020-03-04
488
글번호 136586
답변완료
아래와 비슷하지만 부탁드립니다.
Input:변동률(0.2),레벨(4),선두께(3);
Var:행(0),열(0),고점(1),저점(-1),신규(1),연장(2),연속(3),삼선(4),cnt(0),
고라인기울기(0),고라인시작(0),고라인끝(0),
저라인기울기(0),저라인시작(0),저라인끝(0),
시작일(0),시작시각(0);
Array:고[10,44](0),저[10,44](0), // 열번호 : 1=가격,2=Index,3=sDate,4=sTime,11=가격,12=Index,13=sDate,14=sTime
최종상태[5](0),처리구분[5](0),TL[3](0),TL1[2](0),고0[10,4](0),저0[10,4](0),결과리턴[8](0);
//=========================================================//
If 레벨 <= 4 Then {
Var1 = 레벨 * 10;
Value1 = ChgRateZigZag301(H,L,변동률,고,저,최종상태,처리구분);
If 최종상태[레벨] == 고점 Then {
If 처리구분[레벨] == 신규 Then
TL[2] = TL_New(저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1],
고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1]);
If 처리구분[레벨] == 연장 Then
TL_SetEnd(TL[2],고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1]);
If 처리구분[레벨] == 연속 Then {
TL[1] = TL_New(고[2,Var1 + 3],고[2,Var1 + 4],고[2,Var1 + 1],
저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1]);
TL[2] = TL_New(저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1],
고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1]);
}
If 처리구분[레벨] == 삼선 Then {
TL[0] = TL_New(저[2,Var1 + 3],저[2,Var1 + 4],저[2,Var1 + 1],
고[2,Var1 + 3],고[2,Var1 + 4],고[2,Var1 + 1]);
TL[1] = TL_New(고[2,Var1 + 3],고[2,Var1 + 4],고[2,Var1 + 1],
저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1]);
TL[2] = TL_New(저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1],
고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1]);
}
}
If 최종상태[레벨] == 저점 Then {
If 처리구분[레벨] == 신규 Then
TL[2] = TL_New(고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1],
저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1]);
If 처리구분[레벨] == 연장 Then
TL_SetEnd(TL[2],저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1]);
If 처리구분[레벨] == 연속 Then {
TL[1] = TL_New(저[2,Var1 + 3],저[2,Var1 + 4],저[2,Var1 + 1],
고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1]);
TL[2] = TL_New(고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1],
저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1]);
}
If 처리구분[레벨] == 삼선 Then {
TL[0] = TL_New(고[2,Var1 + 3],고[2,Var1 + 4],고[2,Var1 + 1],
저[2,Var1 + 3],저[2,Var1 + 4],저[2,Var1 + 1]);
TL[1] = TL_New(저[2,Var1 + 3],저[2,Var1 + 4],저[2,Var1 + 1],
고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1]);
TL[2] = TL_New(고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1],
저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1]);
}
}
} Else {
Alert("4레벨까지만 가능합니다!!");
}
//=========================================================//
cnt = cnt + 1;
If (처리구분[레벨] == 신규 or 처리구분[레벨] == 연속) Then {
For 행 = 1 To 10 {
For 열 = 1 To 4 { // 추세채널을 판단할 레벨만 사용자함수에 전달
고0[행,열] = 고[행,Var1 + 열];
저0[행,열] = 저[행,Var1 + 열];
}
}
Value2 = YHS_Channel(고0,저0,결과리턴);
If Value2 == 1 Then { // 추세대가 형성되었다면
시작일 = 결과리턴[0];
시작시각 = 결과리턴[1];
고라인기울기 = 결과리턴[2];
고라인시작 = 결과리턴[3];
고라인끝 = 결과리턴[4];
저라인기울기 = 결과리턴[5];
저라인시작 = 결과리턴[6];
저라인끝 = 결과리턴[7];
If 고라인시작[1] == 고라인시작 and 고라인기울기[1] == 고라인기울기 Then { // 겹쳐 그리지 않도록
TL_SetEnd(TL1[0],sDate,sTime,고라인끝);
} Else {
TL1[0] = TL_New(시작일,시작시각,고라인시작,sDate,sTime,고라인끝);
TL_SetColor(TL1[0],IFF(고라인기울기<0,RED,BLUE));
TL_SetSize(TL1[0],선두께);
}
If 저라인시작[1] == 저라인시작 and 저라인기울기[1] == 저라인기울기 Then {
TL_SetEnd(TL1[1],sDate,sTime,저라인끝);
} Else {
TL1[1] = TL_New(시작일,시작시각,저라인시작,sDate,sTime,저라인끝);
TL_SetColor(TL1[1],IFF(고라인기울기<0,RED,BLUE));
TL_SetSize(TL1[1],선두께);
}
cnt = 0;
Plot1(고라인끝,"고점추세선",IFF(고라인기울기<0,RED,BLUE));
Plot2(저라인끝,"저점추세선",IFF(고라인기울기<0,RED,BLUE));
}
}
If cnt > 0 and cnt < (레벨 + 1) * 20 Then {
고라인끝 = 고라인끝 + 고라인기울기;
저라인끝 = 저라인끝 + 저라인기울기;
If 고라인끝 > 0 Then Plot1(고라인끝,"고점추세선",IFF(고라인기울기<0,RED,BLUE));
If 저라인끝 > 0 Then Plot2(저라인끝,"저점추세선",IFF(고라인기울기<0,RED,BLUE));
}
===================================================================================
제가 드린 수식을 바탕으로 설명해달라고 하셔서 문장으로 적습니다.
위 지표를 아래 문장을 시스템수식으로 변경 부탁드립니다.
* 매수
cnt > 0 and cnt < (레벨 + 1) * 20 일 때,
고라인끝 = 고라인끝 + 고라인기울기;
저라인끝 = 저라인끝 + 저라인기울기;
1. Data1의 종가가 고라인끝 위에 위치하고 있을 때
2. Data2의 현재가가 고라인끝 위에 위치하고 있을 때
3. Data2의 종가가 이동평균선보다 위에 있을 때
4. Data3의 현재가가 직전봉의 종가보다 위에 위치해 있을 때
* 매도
cnt = 0 일 때,
1. Data1의 종가가 저라인끝 아래에 위치하고 있을 때
2. Data2의 현재가가 저라인끝 아래에 위치하고 있을 때
3. Data2의 종가가 이동평균선보다 아래에 있을 때
4. Data3의 현재가가 직전봉의 종가보다 아래에 위치해 있을 때
* 익절
진입가 대비 20틱 (틱수는 변경 가능하도록 부탁드립니다)
* 손절
진입가 대비 15틱 (틱수는 변경 가능하도록 부탁드립니다)
부탁드립니다.
감사합니다.
2020-03-04
404
글번호 136583
답변완료
문의 드립니다
Input:변동률(0.2),레벨(4),선두께(3);
Var:행(0),열(0),고점(1),저점(-1),신규(1),연장(2),연속(3),삼선(4),cnt(0),
고라인기울기(0),고라인시작(0),고라인끝(0),
저라인기울기(0),저라인시작(0),저라인끝(0),
시작일(0),시작시각(0);
Array:고[10,44](0),저[10,44](0), // 열번호 : 1=가격,2=Index,3=sDate,4=sTime,11=가격,12=Index,13=sDate,14=sTime
최종상태[5](0),처리구분[5](0),TL[3](0),TL1[2](0),고0[10,4](0),저0[10,4](0),결과리턴[8](0);
//=========================================================//
If 레벨 <= 4 Then {
Var1 = 레벨 * 10;
Value1 = ChgRateZigZag301(H,L,변동률,고,저,최종상태,처리구분);
If 최종상태[레벨] == 고점 Then {
If 처리구분[레벨] == 신규 Then
TL[2] = TL_New(저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1],
고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1]);
If 처리구분[레벨] == 연장 Then
TL_SetEnd(TL[2],고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1]);
If 처리구분[레벨] == 연속 Then {
TL[1] = TL_New(고[2,Var1 + 3],고[2,Var1 + 4],고[2,Var1 + 1],
저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1]);
TL[2] = TL_New(저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1],
고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1]);
}
If 처리구분[레벨] == 삼선 Then {
TL[0] = TL_New(저[2,Var1 + 3],저[2,Var1 + 4],저[2,Var1 + 1],
고[2,Var1 + 3],고[2,Var1 + 4],고[2,Var1 + 1]);
TL[1] = TL_New(고[2,Var1 + 3],고[2,Var1 + 4],고[2,Var1 + 1],
저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1]);
TL[2] = TL_New(저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1],
고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1]);
}
}
If 최종상태[레벨] == 저점 Then {
If 처리구분[레벨] == 신규 Then
TL[2] = TL_New(고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1],
저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1]);
If 처리구분[레벨] == 연장 Then
TL_SetEnd(TL[2],저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1]);
If 처리구분[레벨] == 연속 Then {
TL[1] = TL_New(저[2,Var1 + 3],저[2,Var1 + 4],저[2,Var1 + 1],
고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1]);
TL[2] = TL_New(고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1],
저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1]);
}
If 처리구분[레벨] == 삼선 Then {
TL[0] = TL_New(고[2,Var1 + 3],고[2,Var1 + 4],고[2,Var1 + 1],
저[2,Var1 + 3],저[2,Var1 + 4],저[2,Var1 + 1]);
TL[1] = TL_New(저[2,Var1 + 3],저[2,Var1 + 4],저[2,Var1 + 1],
고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1]);
TL[2] = TL_New(고[1,Var1 + 3],고[1,Var1 + 4],고[1,Var1 + 1],
저[1,Var1 + 3],저[1,Var1 + 4],저[1,Var1 + 1]);
}
}
} Else {
Alert("4레벨까지만 가능합니다!!");
}
//=========================================================//
cnt = cnt + 1;
If (처리구분[레벨] == 신규 or 처리구분[레벨] == 연속) Then {
For 행 = 1 To 10 {
For 열 = 1 To 4 { // 추세채널을 판단할 레벨만 사용자함수에 전달
고0[행,열] = 고[행,Var1 + 열];
저0[행,열] = 저[행,Var1 + 열];
}
}
Value2 = YHS_Channel(고0,저0,결과리턴);
If Value2 == 1 Then { // 추세대가 형성되었다면
시작일 = 결과리턴[0];
시작시각 = 결과리턴[1];
고라인기울기 = 결과리턴[2];
고라인시작 = 결과리턴[3];
고라인끝 = 결과리턴[4];
저라인기울기 = 결과리턴[5];
저라인시작 = 결과리턴[6];
저라인끝 = 결과리턴[7];
If 고라인시작[1] == 고라인시작 and 고라인기울기[1] == 고라인기울기 Then { // 겹쳐 그리지 않도록
TL_SetEnd(TL1[0],sDate,sTime,고라인끝);
} Else {
TL1[0] = TL_New(시작일,시작시각,고라인시작,sDate,sTime,고라인끝);
TL_SetColor(TL1[0],IFF(고라인기울기<0,RED,BLUE));
TL_SetSize(TL1[0],선두께);
}
If 저라인시작[1] == 저라인시작 and 저라인기울기[1] == 저라인기울기 Then {
TL_SetEnd(TL1[1],sDate,sTime,저라인끝);
} Else {
TL1[1] = TL_New(시작일,시작시각,저라인시작,sDate,sTime,저라인끝);
TL_SetColor(TL1[1],IFF(고라인기울기<0,RED,BLUE));
TL_SetSize(TL1[1],선두께);
}
cnt = 0;
Plot1(고라인끝,"고점추세선",IFF(고라인기울기<0,RED,BLUE));
Plot2(저라인끝,"저점추세선",IFF(고라인기울기<0,RED,BLUE));
}
}
If cnt > 0 and cnt < (레벨 + 1) * 20 Then {
고라인끝 = 고라인끝 + 고라인기울기;
저라인끝 = 저라인끝 + 저라인기울기;
If 고라인끝 > 0 Then Plot1(고라인끝,"고점추세선",IFF(고라인기울기<0,RED,BLUE));
If 저라인끝 > 0 Then Plot2(저라인끝,"저점추세선",IFF(고라인기울기<0,RED,BLUE));
}
===================================================================================
제가 드린 수식을 바탕으로 설명해달라고 하셔서 문장으로 적습니다.
위 지표를 아래 문장을 시스템수식으로 변경 부탁드립니다.
* 매수
cnt = 0 일 때,
1. Data1의 종가가 고라인끝과 저라인끝 사이에 위치하고 있을 때
2. Data2의 현재가가 고라인끝과 저라인끝 사이에 위치하고 있을 때
3. Data2의 종가가 이동평균선보다 위에 있을 때
4. Data3의 현재가가 직전봉의 종가보다 위에 위치해 있을 때
* 매도
cnt > 0 and cnt < (레벨 + 1) * 20 일 때,
고라인끝 = 고라인끝 + 고라인기울기;
저라인끝 = 저라인끝 + 저라인기울기;
1. Data1의 종가가 고라인끝과 저라인끝 사이에 위치하고 있을 때
2. Data2의 현재가가 고라인끝과 저라인끝 사이에 위치하고 있을 때
3. Data2의 종가가 이동평균선보다 아래에 있을 때
4. Data3의 현재가가 직전봉의 종가보다 아래에 위치해 있을 때
* 익절
진입가 대비 20틱 (틱수는 변경 가능하도록 부탁드립니다)
* 손절
진입가 대비 15틱 (틱수는 변경 가능하도록 부탁드립니다)
부탁드립니다.
감사합니다.
+ 위 지표를 실행하기 위하여 필요한 파일은 첨부하여 올려놨습니다.
2020-03-04
457
글번호 136577