답변완료
예스스팟 주문시 주문수량 오류 발생 건 문의 드립니다.
안녕하세요
다름 아니라 아래 식으로 하여
"매수조건"에서는 자동매수 // "매도조건"에서는 자동매도 를 하려고 하고 있습니다.
오늘 한번 실전으로 종목당 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
657
글번호 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
344
글번호 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
304
글번호 189873
지표
답변완료
종목 검색 부탁드립니다.
* 아래의 조건식에 맞는 종목 검색식 부탁 드립니다.
-- 0봉전 10봉 평균거래량 30만 이상
-- 5일 평균거래대금(단위:백만) 5000 이상 100000 이하 (금일포함)
-- 이평이격도: [일] 0봉전(종가 1 ,종가 240) 100 이상 110 이하
-- 상세이평돌파 : [일] 0봉전 지수 (종가 1) 이평이
지수 (종가 120) 이평을 30봉 이내 골든크로스 1회 이상
-- 상세이평돌파 : [일] 0봉전 지수 (종가 1) 이평이
지수 (종가 240) 이평을 30봉 이내 골든크로스 1회 이상
-- 상세이평돌파 : [일] 0봉전 지수 (종가 1) 이평이
지수 (종가 480) 이평을 30봉 이내 골든크로스 1회 이상
-- 주가이평배열(3) : [일] 0봉전 120 이평<= 240 이평<= 480 이평
-- [일] 0봉전 일목균형표 (9,26,52) 주가 <= 선행스팬 1
-- [일] 0봉전 일목균형표 (9,26,52) 주가 <= 선행스팬 2
-- [일] 0봉전 볼린저밴드 (20,2) 30봉 이내에서 종가 상한선 상향돌파
2025-04-06
347
글번호 189870
종목검색