This commit is contained in:
2018-12-04 23:24:02 +09:00
parent 22b38609cd
commit 9493b9f4d5
7 changed files with 244 additions and 47 deletions

View File

@@ -192,6 +192,7 @@
this.materialTabControl1.SelectedIndex = 0; this.materialTabControl1.SelectedIndex = 0;
this.materialTabControl1.Size = new System.Drawing.Size(1141, 662); this.materialTabControl1.Size = new System.Drawing.Size(1141, 662);
this.materialTabControl1.TabIndex = 2; this.materialTabControl1.TabIndex = 2;
this.materialTabControl1.Visible = false;
// //
// tabPage1 // tabPage1
// //
@@ -1214,7 +1215,7 @@
this.materialLabel3.Name = "materialLabel3"; this.materialLabel3.Name = "materialLabel3";
this.materialLabel3.Size = new System.Drawing.Size(165, 19); this.materialLabel3.Size = new System.Drawing.Size(165, 19);
this.materialLabel3.TabIndex = 6; this.materialLabel3.TabIndex = 6;
this.materialLabel3.Text = "Version : 2018.01.04.12"; this.materialLabel3.Text = "Version : 2018.12.04.13";
// //
// materialLabel2 // materialLabel2
// //
@@ -1521,7 +1522,9 @@
private MaterialSkin.Controls.MaterialTabSelector materialTabSelector1; private MaterialSkin.Controls.MaterialTabSelector materialTabSelector1;
private MaterialSkin.Controls.MaterialTabControl materialTabControl1; private MaterialSkin.Controls.MaterialTabControl materialTabControl1;
private System.Windows.Forms.TabPage tabPage1; private System.Windows.Forms.TabPage tabPage1;
private System.Windows.Forms.TabPage tabPage2;
private System.Windows.Forms.TabPage tabPage3; private System.Windows.Forms.TabPage tabPage3;
private System.Windows.Forms.TabPage tabPage4;
private System.Windows.Forms.SplitContainer splitContainer1; private System.Windows.Forms.SplitContainer splitContainer1;
private ListViewNF lvItems; private ListViewNF lvItems;
private System.Windows.Forms.ColumnHeader chCodeName; private System.Windows.Forms.ColumnHeader chCodeName;
@@ -1558,7 +1561,7 @@
private MaterialSkin.Controls.MaterialSingleLineTextField tbTrailingP; private MaterialSkin.Controls.MaterialSingleLineTextField tbTrailingP;
private MaterialSkin.Controls.MaterialLabel materialLabel5; private MaterialSkin.Controls.MaterialLabel materialLabel5;
private MaterialSkin.Controls.MaterialLabel materialLabel4; private MaterialSkin.Controls.MaterialLabel materialLabel4;
private System.Windows.Forms.TabPage tabPage4;
private MaterialSkin.Controls.MaterialFlatButton btLoad; private MaterialSkin.Controls.MaterialFlatButton btLoad;
private MaterialSkin.Controls.MaterialFlatButton btSimulate; private MaterialSkin.Controls.MaterialFlatButton btSimulate;
private System.Windows.Forms.RichTextBox tbSimulationLog; private System.Windows.Forms.RichTextBox tbSimulationLog;
@@ -1612,7 +1615,6 @@
private MaterialSkin.Controls.MaterialRaisedButton btClearAll; private MaterialSkin.Controls.MaterialRaisedButton btClearAll;
private System.Windows.Forms.SplitContainer splitContainer4; private System.Windows.Forms.SplitContainer splitContainer4;
private MaterialSkin.Controls.MaterialRaisedButton btUpdateNC; private MaterialSkin.Controls.MaterialRaisedButton btUpdateNC;
private System.Windows.Forms.TabPage tabPage2;
private System.Windows.Forms.ListView lvConclusion; private System.Windows.Forms.ListView lvConclusion;
private System.Windows.Forms.ColumnHeader columnHeader2; private System.Windows.Forms.ColumnHeader columnHeader2;
private System.Windows.Forms.ColumnHeader columnHeader3; private System.Windows.Forms.ColumnHeader columnHeader3;

View File

@@ -76,6 +76,23 @@ namespace AutoSellerNS
InitializeComponent(); InitializeComponent();
cbSMMethod.SelectedIndex = 0; cbSMMethod.SelectedIndex = 0;
foreach (TabPage tabPage in materialTabSelector1.BaseTabControl.TabPages)
{
Console.WriteLine(tabPage.Text);
var currentTabIndex = materialTabSelector1.BaseTabControl.TabPages.IndexOf(tabPage);
Console.WriteLine(currentTabIndex);
}
for(int i=0; i< materialTabSelector1.BaseTabControl.TabPages.Count; i++)
{
var tabPage = materialTabSelector1.BaseTabControl.TabPages[i];
Console.WriteLine(tabPage.Text);
var currentTabIndex = materialTabSelector1.BaseTabControl.TabPages.IndexOf(tabPage);
Console.WriteLine(currentTabIndex);
//new Rectangle(MaterialSkinManager.Instance.FORM_PADDING,
}
Util.SetLogView(tbLog); Util.SetLogView(tbLog);
Config.Init(); Config.Init();
@@ -251,6 +268,27 @@ namespace AutoSellerNS
m_CybosHelper.UpdateItems(); m_CybosHelper.UpdateItems();
} }
public void UpdateItem(bool bBid, string strCodeName, string strCode, int iPrice, int iConclusionCnt)
{
lock (m_Items)
{
int iIdx = m_Items.FindIndex(s => s.m_strCode == strCode);
if (iIdx < 0)
{
UpdateItem();
return;
}
ITEM Item = m_Items[iIdx];
Item.m_iItemCnt += bBid ? iConclusionCnt : -iConclusionCnt;
if (Item.m_iItemCnt == 0)
m_Items.RemoveAt(iIdx);
SyncListViewItems(m_Items);
}
}
public void UpdateItemCallback(List<ITEM> Items) public void UpdateItemCallback(List<ITEM> Items)
{ {
SyncItems(m_Items, Items); SyncItems(m_Items, Items);
@@ -309,6 +347,26 @@ namespace AutoSellerNS
m_CybosHelper.UpdateNC(); m_CybosHelper.UpdateNC();
} }
public void UpdateNCItem(bool bConclusion, bool bBid, string strCodeName, string strCode, int iPrice, int iConclusionCnt)
{
lock (m_NCItems)
{
int iIdx = m_NCItems.FindIndex(s => s.m_strCode == strCode);
if (iIdx < 0)
{
UpdateNCItem();
return;
}
NCITEM Item = m_NCItems[iIdx];
Item.m_iRemainCnt += (bConclusion ? -iConclusionCnt : iConclusionCnt);
if (Item.m_iRemainCnt == 0)
m_NCItems.RemoveAt(iIdx);
SyncNCListVIewItems(m_NCItems);
}
}
public void UpdateNCItemCallback(List<AutoSeller.NCITEM> NCItems) public void UpdateNCItemCallback(List<AutoSeller.NCITEM> NCItems)
{ {
SyncNCItems(m_NCItems, NCItems); SyncNCItems(m_NCItems, NCItems);
@@ -780,5 +838,10 @@ namespace AutoSellerNS
lvConclusion.EndUpdate(); lvConclusion.EndUpdate();
})); }));
} }
public void ErrorCallback(string msg)
{
Util.Log(Util.LOG_TYPE.ERROR, msg);
}
} }
} }

View File

@@ -94,6 +94,7 @@
<Reference Include="System.Xml" /> <Reference Include="System.Xml" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Compile Include="ConcurrentList.cs" />
<Compile Include="Config.cs" /> <Compile Include="Config.cs" />
<Compile Include="CurrentItem.cs" /> <Compile Include="CurrentItem.cs" />
<Compile Include="CybosHelper.cs" /> <Compile Include="CybosHelper.cs" />

104
ConcurrentList.cs Normal file
View File

@@ -0,0 +1,104 @@
using System;
using System.Collections.Concurrent;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace AutoSellerNS
{
public class ConcurrentList<T> : ConcurrentDictionary<int, T>, IList<T>
{
int m_Order = 0;
public T this[int index]
{
get
{
T value;
if (ContainsKey(index) == true)
{
TryGetValue(index, out value);
return value;
}
else
{
throw new IndexOutOfRangeException();
}
}
set
{
AddOrUpdate(index, value, (k, v) => value);
}
}
public bool IsReadOnly
{
get
{
return false;
}
}
public void Add(T item)
{
TryAdd(m_Order++, item);
}
public bool Contains(T item)
{
return Contains(item);
}
public void CopyTo(T[] array, int arrayIndex)
{
throw new NotImplementedException();
}
public int IndexOf(T item)
{
foreach(var kv in this)
{
if (kv.Value.Equals(item))
return kv.Key;
}
return -1;
}
public void Insert(int index, T item)
{
if(index < 0 || index >= m_Order)
throw new ArgumentOutOfRangeException();
this[index] = item;
}
public bool Remove(T item)
{
int index = IndexOf(item);
if (index < 0)
return false;
this[index] = default(T);
return true;
}
public void RemoveAt(int index)
{
if (index < 0 || ContainsKey(index) == false)
throw new ArgumentOutOfRangeException();
this[index] = default(T);
}
IEnumerator<T> IEnumerable<T>.GetEnumerator()
{
foreach(var kv in this)
{
yield return kv.Value;
}
}
}
}

View File

@@ -121,7 +121,7 @@ namespace AutoSellerNS
if (m_iCheckCount >= m_dCheckCountLimit && m_Listener.IsSelling() == true) if (m_iCheckCount >= m_dCheckCountLimit && m_Listener.IsSelling() == true)
{ {
await m_CybosHelper.SellItem(m_strCode, m_Listener.GetSellableCount(m_strCode), m_aiAskPrice[0]); await m_CybosHelper.SellItem(m_strCode, m_Listener.GetSellableCount(m_strCode), m_aiAskPrice[0]-m_CybosHelper.GetUnitValue(m_iCurPrice));
Util.Log(Util.LOG_TYPE.SELL, string.Format("[조건 완료 매도] {0} ({1}회) (현재가 {2:n0}원, 최고가 {3:n0}원)", Util.Log(Util.LOG_TYPE.SELL, string.Format("[조건 완료 매도] {0} ({1}회) (현재가 {2:n0}원, 최고가 {3:n0}원)",
m_strCodeName, m_strCodeName,
Config.GetBidCount(), Config.GetBidCount(),
@@ -133,7 +133,7 @@ namespace AutoSellerNS
m_iTrailingCount++; m_iTrailingCount++;
if (m_iTrailingCount >= Config.GetTrailingCnt() && m_Listener.IsSelling() == true) if (m_iTrailingCount >= Config.GetTrailingCnt() && m_Listener.IsSelling() == true)
{ {
await m_CybosHelper.SellItem(m_strCode, m_Listener.GetSellableCount(m_strCode), m_aiAskPrice[0]); await m_CybosHelper.SellItem(m_strCode, m_Listener.GetSellableCount(m_strCode), m_aiAskPrice[0]-m_CybosHelper.GetUnitValue(m_iCurPrice));
Util.Log(Util.LOG_TYPE.SELL, string.Format("[트레일링 매도] {0} ({1}% {2}회) (현재가 {3:n0}원, 최고가 {4:n0}원)", Util.Log(Util.LOG_TYPE.SELL, string.Format("[트레일링 매도] {0} ({1}% {2}회) (현재가 {3:n0}원, 최고가 {4:n0}원)",
m_strCodeName, m_strCodeName,
Config.GetTrailingRate(), Config.GetTrailingRate(),
@@ -144,7 +144,7 @@ namespace AutoSellerNS
if (iTimeDiff >= Config.GetTimeLimit() && m_Listener.IsSelling() == true) if (iTimeDiff >= Config.GetTimeLimit() && m_Listener.IsSelling() == true)
{ {
await m_CybosHelper.SellItem(m_strCode, m_Listener.GetSellableCount(m_strCode), m_aiAskPrice[0]); await m_CybosHelper.SellItem(m_strCode, m_Listener.GetSellableCount(m_strCode), m_aiAskPrice[0]-m_CybosHelper.GetUnitValue(m_iCurPrice));
Util.Log(Util.LOG_TYPE.SELL, string.Format("[시간제한 매도] {0} ({1}초) (현재가 {2:n0}원, 최고가 {3:n0}원)", Util.Log(Util.LOG_TYPE.SELL, string.Format("[시간제한 매도] {0} ({1}초) (현재가 {2:n0}원, 최고가 {3:n0}원)",
m_strCodeName, m_strCodeName,
iTimeDiff, iTimeDiff,

View File

@@ -180,16 +180,19 @@ namespace AutoSellerNS
if (Config.GetAccount() == "") if (Config.GetAccount() == "")
return; return;
m_CP6033.SetInputValue(0, Config.GetAccount());
m_CP6033.SetInputValue(1, Config.GetSubAccount());
m_CP6033.SetInputValue(2, 50);
string Msg1 = m_CP6033.GetDibMsg1(); string Msg1 = m_CP6033.GetDibMsg1();
string Msg2 = m_CP6033.GetDibMsg2(); string Msg2 = m_CP6033.GetDibMsg2();
int iStatus = m_CP6033.GetDibStatus(); int iStatus = m_CP6033.GetDibStatus();
if (iStatus == 1) if (iStatus == 1)
return; return;
if (iStatus == -1)
m_Listener.ErrorCallback($"Update Item Error\nStatus: {iStatus}\nMsg1: {Msg1}\nMsg2: {Msg2}");
m_CP6033.SetInputValue(0, Config.GetAccount());
m_CP6033.SetInputValue(1, Config.GetSubAccount());
m_CP6033.SetInputValue(2, 50);
m_CP6033.Request(); m_CP6033.Request();
} }
@@ -275,8 +278,8 @@ namespace AutoSellerNS
public void UpdateNC() public void UpdateNC()
{ {
m_CP5339.SetInputValue(0, Config.GetAccount()); if (Config.GetAccount() == "")
m_CP5339.SetInputValue(1, Config.GetSubAccount()); return;
string Msg1 = m_CP5339.GetDibMsg1(); string Msg1 = m_CP5339.GetDibMsg1();
string Msg2 = m_CP5339.GetDibMsg2(); string Msg2 = m_CP5339.GetDibMsg2();
@@ -284,6 +287,11 @@ namespace AutoSellerNS
if (iStatus == 1) if (iStatus == 1)
return; return;
if (iStatus == -1)
m_Listener.ErrorCallback($"UpdateNC Item Error\nStatus: {iStatus}\nMsg1: {Msg1}\nMsg2: {Msg2}");
m_CP5339.SetInputValue(0, Config.GetAccount());
m_CP5339.SetInputValue(1, Config.GetSubAccount());
m_CP5339.Request(); m_CP5339.Request();
} }
@@ -334,12 +342,19 @@ namespace AutoSellerNS
int iPrice = m_CpConclusion.GetHeaderValue(4); int iPrice = m_CpConclusion.GetHeaderValue(4);
int iOrderNumber = m_CpConclusion.GetHeaderValue(5); int iOrderNumber = m_CpConclusion.GetHeaderValue(5);
int iOrgOrderNumber = m_CpConclusion.GetHeaderValue(6); int iOrgOrderNumber = m_CpConclusion.GetHeaderValue(6);
string strCancel = m_CpConclusion.GetHeaderValue(16); string strOrderType = m_CpConclusion.GetHeaderValue(16);
string strOrderCondition = m_CpConclusion.GetHeaderValue(19); string strOrderCondition = m_CpConclusion.GetHeaderValue(19);
int iBookValue = m_CpConclusion.GetHeaderValue(21); int iBookValue = m_CpConclusion.GetHeaderValue(21);
int iRemainCnt = m_CpConclusion.GetHeaderValue(23); int iRemainCnt = m_CpConclusion.GetHeaderValue(23);
string strBidOrAsk = bBid ? "매수" : "매도"; string strBidOrAsk = bBid ? "매수" : "매도";
if (strOrderType == "1")
strOrderType = "정상 주문";
else if (strOrderType == "2")
strOrderType = "정정 주문";
else if (strOrderType == "3")
strOrderType = "취소 주문";
if (strOrderCondition == "0") if (strOrderCondition == "0")
strOrderCondition = "없음"; strOrderCondition = "없음";
else if (strOrderCondition == "1") else if (strOrderCondition == "1")
@@ -350,22 +365,29 @@ namespace AutoSellerNS
switch (iType) switch (iType)
{ {
case 1: // 체결 case 1: // 체결
m_Listener.UpdateItem(); m_Listener.UpdateItem(bBid, strCodeName, strCode, iPrice, iConclusionCnt);
m_Listener.UpdateNCItem(); m_Listener.UpdateNCItem();
Util.Log(bBid?Util.LOG_TYPE.BUY_CONCLUSION:Util.LOG_TYPE.SELL_CONCLUSION, string.Format("{0}:{1} {2} 체결 ({3:n0}원 {4}주) - {5}", strCodeName, strCode, strBidOrAsk, iPrice, iConclusionCnt, strOrderCondition)); //if (strOrderType == "정상 주문")
// m_Listener.UpdateNCItem(true, bBid, strCodeName, strCode, iPrice, iConclusionCnt);
Util.Log(bBid?Util.LOG_TYPE.BUY_CONCLUSION:Util.LOG_TYPE.SELL_CONCLUSION, string.Format("{0}:{1} {2} {3} 체결 ({4:n0}원 {5}주) - {6}",
strCodeName, strCode, strBidOrAsk, strOrderType, iPrice, iConclusionCnt, strOrderCondition));
break; break;
case 2: // 확인 case 2: // 확인
Util.Log(Util.LOG_TYPE.VERBOSE, string.Format("{0}:{1} {2} 확인 - {3} ({4}:{5})", strCodeName, strCode, strBidOrAsk, strOrderCondition, iOrderNumber, iOrgOrderNumber)); Util.Log(Util.LOG_TYPE.VERBOSE, string.Format("{0}:{1} {2} {3} 확인 - {4} ({5}:{6})",
strCodeName, strCode, strBidOrAsk, strOrderType, strOrderCondition, iOrderNumber, iOrgOrderNumber));
break; break;
case 3: // 거부 case 3: // 거부
Util.Log(Util.LOG_TYPE.VERBOSE, string.Format("{0}:{1} {2} 거부", strCodeName, strCode, strBidOrAsk)); Util.Log(Util.LOG_TYPE.VERBOSE, string.Format("{0}:{1} {2} {3} 거부", strCodeName, strCode, strBidOrAsk, strOrderType));
break; break;
case 4: // 접수 case 4: // 접수
m_Listener.UpdateNCItem(); m_Listener.UpdateNCItem();
Util.Log(bBid ? Util.LOG_TYPE.BUY : Util.LOG_TYPE.SELL, string.Format("{0}:{1} {2} 접수 ({3:n0}원 {4}주) - {5}", strCodeName, strCode, strBidOrAsk, iPrice, iConclusionCnt, strOrderCondition)); //if(strOrderType == "정상 주문")
// m_Listener.UpdateNCItem(false, bBid, strCodeName, strCode, iPrice, iConclusionCnt);
Util.Log(bBid ? Util.LOG_TYPE.BUY : Util.LOG_TYPE.SELL, string.Format("{0}:{1} {2} {3} 접수 ({4:n0}원 {5}주) - {6}",
strCodeName, strCode, strBidOrAsk, strOrderType, iPrice, iConclusionCnt, strOrderCondition));
if (bBid == false) if (bBid == false)
{ {
if(m_aStockCur.ContainsKey(strCode) == true) if(m_aStockCur.ContainsKey(strCode) == true)
@@ -498,7 +520,7 @@ namespace AutoSellerNS
await Task.Run(() => await Task.Run(() =>
{ {
int iSellPrice = iAskPrice - GetUnitValue(iAskPrice); int iSellPrice = iAskPrice;
CPTRADELib.CpTd0311 Td0311 = new CPTRADELib.CpTd0311(); CPTRADELib.CpTd0311 Td0311 = new CPTRADELib.CpTd0311();
Td0311.SetInputValue(0, "1"); Td0311.SetInputValue(0, "1");
@@ -563,8 +585,9 @@ namespace AutoSellerNS
{ {
await Task.Run(() => await Task.Run(() =>
{ {
CancelItem(strCode, iOrgOrderNo).Wait(); var a = CancelItem(strCode, iOrgOrderNo);
SellItem(strCode, iCnt, iAskPrice).Wait(); Thread.Sleep(2000);
a = SellItem(strCode, iCnt, iAskPrice);
string strCode2; string strCode2;
m_ItemsInCorrection.TryRemove(iOrgOrderNo, out strCode2); m_ItemsInCorrection.TryRemove(iOrgOrderNo, out strCode2);

View File

@@ -33,7 +33,7 @@ namespace AutoSellerNS
StockBid CPStockBid = new StockBid(); StockBid CPStockBid = new StockBid();
ExcelHandler Excel = null; ExcelHandler Excel = null;
foreach(string strLine in File.ReadLines(Util.GetSimulationPath()+"/0-input.txt", Encoding.UTF8)) foreach(string strLine in File.ReadLines(GetInputFileName(), Encoding.UTF8))
{ {
var tokens = strLine.Split('\t'); var tokens = strLine.Split('\t');
@@ -210,6 +210,10 @@ namespace AutoSellerNS
var tokens = strLine.Split('\t'); var tokens = strLine.Split('\t');
if (tokens == null || tokens.Length <= 4)
return new object[] { "input error \n", 0 };
var strDate = tokens[0]; var strDate = tokens[0];
var strSimulationTime = tokens[1]; var strSimulationTime = tokens[1];
var strCodeName = tokens[2]; var strCodeName = tokens[2];
@@ -311,8 +315,6 @@ namespace AutoSellerNS
iStockCount = 1000000/iStartPrice; iStockCount = 1000000/iStartPrice;
if(bStart == false) if(bStart == false)
{
if(RowDT >= StartDT && iPrice==iStartPrice)
{ {
bStart = true; bStart = true;
iStartRow = iRow; iStartRow = iRow;
@@ -329,14 +331,6 @@ namespace AutoSellerNS
m_PriceList.Clear(); m_PriceList.Clear();
m_PriceList.Add(iPrice); m_PriceList.Add(iPrice);
} }
else if((RowDT-StartDT).Minutes > 10)
{
InsertLog(string.Format("[{0}] [{1}] 매수 가격 찾기 실패\n",
StartDT.ToString("yyyy-MM-dd"),
strCodeName));
break;
}
}
else else
{ {
m_PriceList.Add(iPrice); m_PriceList.Add(iPrice);
@@ -684,7 +678,7 @@ namespace AutoSellerNS
List<string> aLines = new List<string>(); List<string> aLines = new List<string>();
List<Task<object>> aTasks = new List<Task<object>>(); List<Task<object>> aTasks = new List<Task<object>>();
foreach(string strLine in File.ReadLines(Util.GetSimulationPath()+"/0-input.txt", Encoding.UTF8)) foreach(string strLine in File.ReadLines(GetInputFileName(), Encoding.UTF8))
{ {
var task = Task.Factory.StartNew<object>(() => var task = Task.Factory.StartNew<object>(() =>
SimulationWork(new object[] { SimulationWork(new object[] {
@@ -775,6 +769,16 @@ namespace AutoSellerNS
}); });
} }
string GetInputFileName()
{
string strPath = Util.GetSimulationPath() + "/0-input-" + DateTime.Now.Date.ToString("yyyy-MM-dd") + ".txt";
if (File.Exists(strPath) == true)
return strPath;
strPath = Util.GetSimulationPath() + "/0-input.txt";
return strPath;
}
public static void InsertSimulationLog(string strCode, string strCodeName, List<Tuple<int, int>> PriceDealCntList) public static void InsertSimulationLog(string strCode, string strCodeName, List<Tuple<int, int>> PriceDealCntList)
{ {
DateTime time = DateTime.Now; DateTime time = DateTime.Now;