답변완료
수식변환 부탁드립니다.
안녕하세요
수식변환 부탁드립니다.
전환선=(highest(high,shortPeriod)+lowest(low,shortPeriod))/2;
기준선=(highest(high,midPeriod)+lowest(low,midPeriod))/2;
선행1=(highest(high,shortPeriod)+lowest(low,shortPeriod)+highest(high,midPeriod)+lowest(low,midPeriod))/4;
선행2=(highest(high,longPeriod)+lowest(low,longPeriod))/2;
조건=CrossUp(선행1,선행2)&&전환선>기준선;
ValueWhen(1,조건,선행1)
조건
shortPeriod 9
midPeriod 26
longPeriod 52
2025-04-07
299
글번호 189897
지표
답변완료
예스스팟 주문시 주문수량 오류 발생 건 문의 드립니다.
안녕하세요
다름 아니라 아래 식으로 하여
"매수조건"에서는 자동매수 // "매도조건"에서는 자동매도 를 하려고 하고 있습니다.
오늘 한번 실전으로 종목당 10만원씩 테스트를 해보려고 하는데, 첨부 파일과 같이
주문 수량이 잘못되었다고 자꾸 에러 메세지가 뜹니다.
매수하려는 종목 자체가 주당 2000원짜리라서 한주당 가격이 높아서 그런것도 아닌거 같은데
이게... 제가 착각일수도 있는데 금요일에 시험삼아 해봤을 때는 정상 매수가 되었습니다.
그런데 오늘은 이상하게 안되네요..제가 수정을 하면서 좀 건드렸는지..
제가 아무리 뜯어봐도 딱히 문제가 될 부분은 없어 보이는데 (검증해도 이상은 없다고 나옵니다.)
첨부된 파일에 오류가 5개 떠있는데 이건 제가 자꾸 테스트한다고 껏다가 켯다가 해서 5개가 떠있는거고, 한번 켤때 1개 에러난 후 먹통입니다.
혹시 원인을 알수 있을지 문의 드립니다.
var timer5 = 2; // 2초
var 매수금 = 100000;
var OrderList = [];
var MKList = [];
var req;
var 종목제한수 = 5;
var Search;
function Main_OnStart()
{
Main.SetTimer(1, timer5 * 1000);
MKList = [];
Search = 1;
}
function Main_OnTimer(nEventID)
{
var d = new Date();
YYYYMMDD = d.getFullYear() * 10000 + (d.getMonth() + 1) * 100 + d.getDate();
HHMMSS = d.getHours() * 10000 + d.getMinutes() * 100 + d.getSeconds();
if (nEventID == 1 && HHMMSS > 090000 && HHMMSS < 151800)
{
Main.MessageList(Search);
if (Search == 1)
{
Main.ReqPowerSearch("매수조건");
}
else
{
Main.ReqPowerSearch("매도조건");
}
Main.KillTimer(1);
}
if (nEventID == 2)
{
Main.ReqMarketData(OrderList[req]);
Main.KillTimer(2);
}
}
function Main_OnRcvItemList(aItemList, nCount)
{
Main.MessageList(nCount);
OrderList = [];
if (Search == 1)
{
if (nCount >= 1)
{
if (MKList.length == 0)
{
OrderList = aItemList.slice(0, 종목제한수); //한정된 수만 가져오기
}
else
{
for (var a = 0; a < nCount; a++)
{
var Add = true;
for (var b = 0; b < MKList.length; b++)
{
if (aItemList[a] == MKList[b].code)
{
Add = false;
}
}
if (Add == true && !IsStockInAccount(aItemList[a]))
{
OrderList.push(aItemList[a]);
//제한 수를 넘는 경우 break
if (OrderList.length >= 종목제한수)
{
break;
}
}
}
}
if (OrderList.length == 0)
{
Main.SetTimer(1, timer5 * 1000);
}
else
{
req = 0;
Main.ReqMarketData(OrderList[req]);
}
}
Search = -1;
}
else
{
if (nCount >= 1)
{
for (var a = 0; a < aItemList.Length; a++)
{
for (var b = 0; b < MKList.length; b++)
{
if (aItemList[a] == MKList[b].code)
{
Account1.SetBalance(aItemList[a], 0);
if (Account1.Balance.count > 0)
{
Account1.OrderSell(Account1.Balance.code,Account1.Balance.countc,0,1);
}
}
}
}
}
Main.SetTimer(1, timer5 * 1000);
Search = 1;
}
}
function Main_OnRcvMarketData(MarketData)
{
if (MarketData.code == OrderList[req])
{
MKList.push(MarketData);
//계좌에 같은 종목이 있는지 확인
if (!IsStockInAccount(MarketData.code))
{
//계좌에 없는 경우에만 매수
//Account1.OrderBuy(MarketData.code, 1, 0, 1);
Account1.OrderBuy(MarketData.code, Math.floor(매수금 / MarketData.Ask(1)),0,1); //10만원 시장가 주문
//Account1.OrderBuy(MarketData.code, Math.floor(매수금 / MarketData.Ask(1)), MarketData.Ask(1), 0);
// 1번 시장가 1개씩, 2번 시장가,매수금만큼 주문, 3번 지정가(+1호가), 매수금만큼 주문
Main.MessageList(MarketData.code + " 주식을 매수합니다.");
}
else
{
Main.MessageList(MarketData.code + " 주식은 이미 계좌에 있으므로 매수하지 않습니다.");
}
req = req + 1;
if (req < OrderList.length)
{
var aa = Main.ReqMarketData(OrderList[req]);
if (aa == -1)
{
Main.SetTimer(2, 15000);
}
}
else
{
Main.SetTimer(1, timer5 * 1000);
}
}
}
function IsStockInAccount(stockCode)
{
//계좌에 해당 종목이 있는지 확인하는 함수
var numberOfBalances = Account1.GetTheNumberOfBalances();
for (var i = 0; i < numberOfBalances; i++)
{
Account1.SetBalance(i);
if (stockCode == Account1.Balance.code)
{
return true; //계좌에 같은 종목이 있으면 true반환
}
}
return false; //계좌에 같은 종목이 없으면 false 반환
}
2025-04-07
621
글번호 189895
종목검색
답변완료
질문드리겠습니다
안녕하세요
분봉상에서 7일간 합산 거래대금과 평균거래대금 (2가지로 각각 나눠서 부탁드립니다) 을 분봉에서 다음날 첫봉 완료시에 (첫봉에만) 표시하는 수식을 부탁드립니다
예를 들어서 오늘 첫봉 완료시에, 이전 7일간의 대금 합 (대금 평균) 을 표시하려고 합니다.
질문2)
배열 관련 질문인데요
var 에서 배열을 45개까지 선언을 했는데
아래에서 처럼 tttl[46] (45개 초과) 를 불러오면 어떤 현상이 나타나게 되는거에요??
차트 전체의 모든 추세선이 나타나는거 같은데요 배열에 저장이 안돼있을텐데 모두 다 나오는 이유가 궁금하네요.,,
var: tttl[45](0),sd[45](0),st[45](0);
For cnt = 40 DownTo 1
{
tttl[cnt] = tttl[cnt-1];
sd[cnt] =sd[cnt-1];
st[cnt] =st[cnt-1];
}
sd[0] = sDate;
st[0] = sTime;
TL_SetExtRight(tttl[46],False);
tttl[0]=tl_new(sd[1],st[1],aa[0],sd[0],st[0],aa[0]);
TL_SetSize(tttl[0],0);
TL_SetDrawMode(tttl[0],0);
TL_Delete(tttl[46]);
TL_SetExtRight(tttl[0],true);
감사합니다
2025-04-07
300
글번호 189883
지표
답변완료
수식 수정 의뢰 드립니다.
안녕하세요!
아래 만들어 주신 수식을 당일에만 나타나도록 수정을 부탁 드립니다.
input : Price1(1.2),Price2(2.5),Price3(3.0);
var : cond2(False,Data2);
var : cond4(False,Data4);
var : cond6(False,Data6);
var : cond8(False,Data8);
cond2 = CrossUp(data2(HighD(0)),data3(HighD(0))) or
CrossDown(data2(LowD(0)),data3(LowD(0))) or
CrossUp(data3(HighD(0)),data2(HighD(0))) or
CrossDown(data3(LowD(0)),data2(LowD(0)));
cond4 = CrossUp(data4(HighD(0)),data5(HighD(0))) or
CrossDown(data4(LowD(0)),data5(LowD(0))) or
CrossUp(data5(HighD(0)),data4(HighD(0))) or
CrossDown(data5(LowD(0)),data4(LowD(0)));
cond6 = CrossUp(data6(HighD(0)),data7(HighD(0))) or
CrossDown(data6(LowD(0)),data7(LowD(0))) or
CrossUp(data7(HighD(0)),data6(HighD(0))) or
CrossDown(data7(LowD(0)),data6(LowD(0)));
cond8 = CrossUp(data8(HighD(0)),data9(HighD(0))) or
CrossDown(data8(LowD(0)),data9(LowD(0))) or
CrossUp(data9(HighD(0)),data8(HighD(0))) or
CrossDown(data9(LowD(0)),data8(LowD(0)));
if cond2 == true Then
var2 = Data1(c);
if cond4 == true Then
var4 = Data1(c);
if cond6 == true Then
var6 = Data1(c);
if cond8 == true Then
var8 = Data1(c);
if var2 > 0 Then
Plot1(var2,"d2");
if var4 > 0 Then
Plot2(var4,"d4");
if var6 > 0 Then
Plot3(var6,"d6");
if var8 > 0 Then
Plot4(var8,"d8");
2025-04-06
271
글번호 189873
지표