init
This commit is contained in:
@@ -1,4 +1,5 @@
|
||||
import pandas as pd
|
||||
|
||||
from stock.analysis.Common import Common
|
||||
from stock.analysis.Stochastic import Stochastic
|
||||
from stock.analysis.RSI import RSI
|
||||
@@ -6,7 +7,6 @@ from stock.analysis.MACD import MACD
|
||||
from stock.analysis.IchimokuCloud import IchimokuCloud
|
||||
|
||||
class BuySellChecker:
|
||||
|
||||
common = None
|
||||
stochastic = None
|
||||
rsi = None
|
||||
@@ -23,8 +23,8 @@ class BuySellChecker:
|
||||
self.ichimokuCloud = IchimokuCloud()
|
||||
|
||||
self.BUY_COUNT = 0
|
||||
return
|
||||
|
||||
return
|
||||
|
||||
def isYangbong(self, data, i):
|
||||
if data['close'][i] > data['open'][i]:
|
||||
@@ -67,23 +67,28 @@ class BuySellChecker:
|
||||
|
||||
check_under_20_for_10 = False
|
||||
for c in range(i - within, i - during):
|
||||
value = [1 if max(data['avg3'][d], data['avg6'][d], data['avg9'][d], data['avg12'][d]) < data['avg20'][d] else 0 for d in range(c, c + during)]
|
||||
value = [
|
||||
1 if max(data['avg3'][d], data['avg6'][d], data['avg9'][d], data['avg12'][d]) < data['avg20'][d] else 0
|
||||
for d in range(c, c + during)]
|
||||
if len(value) == during and sum(value) == during:
|
||||
check_under_20_for_10 = True
|
||||
break
|
||||
return check_under_20_for_10
|
||||
|
||||
def max_min_avg(self, data, i):
|
||||
return max(data['avg3'][i], data['avg6'][i], data['avg9'][i], data['avg12'][i], data['avg20'][i]) - min(data['avg3'][i], data['avg6'][i], data['avg9'][i], data['avg12'][i], data['avg20'][i])
|
||||
return max(data['avg3'][i], data['avg6'][i], data['avg9'][i], data['avg12'][i], data['avg20'][i]) - min(
|
||||
data['avg3'][i], data['avg6'][i], data['avg9'][i], data['avg12'][i], data['avg20'][i])
|
||||
|
||||
def check_inverse_arrangement_before(self, data, i, within=30, during=5):
|
||||
if i - within < 381:
|
||||
return False
|
||||
|
||||
inverse_arrangement = False
|
||||
for c in range(i-within, i-during):
|
||||
value = [1 if data['avg3'][d] < data['avg6'][d] < data['avg9'][d] < data['avg12'][d] < data['avg20'][d] else 0 for d in range(c, c + during)]
|
||||
if len(value) == during and sum(value) == during-1:
|
||||
for c in range(i - within, i - during):
|
||||
value = [
|
||||
1 if data['avg3'][d] < data['avg6'][d] < data['avg9'][d] < data['avg12'][d] < data['avg20'][d] else 0
|
||||
for d in range(c, c + during)]
|
||||
if len(value) == during and sum(value) == during - 1:
|
||||
inverse_arrangement = True
|
||||
break
|
||||
return inverse_arrangement
|
||||
@@ -91,15 +96,15 @@ class BuySellChecker:
|
||||
def checkUpDirection(self, data, i):
|
||||
# 0: 무추세, -1: 하락 추세, 1: 상승 추세
|
||||
close = data['close'][i]
|
||||
#up_count = sum([1 if data['high'][c] < close else 0 for c in range(i-20, i)])
|
||||
#down_count = sum([1 if close < data['low'][c] else 0 for c in range(i - 20, i)])
|
||||
# up_count = sum([1 if data['high'][c] < close else 0 for c in range(i-20, i)])
|
||||
# down_count = sum([1 if close < data['low'][c] else 0 for c in range(i - 20, i)])
|
||||
|
||||
lagging_change = sum([1 if data['laggingSpan'][c] < data['changeLine'][c] else 0 for c in range(i-20, i)])
|
||||
change_lagging = sum([1 if data['laggingSpan'][c] > data['changeLine'][c] else 0 for c in range(i-20, i)])
|
||||
lagging_change = sum([1 if data['laggingSpan'][c] < data['changeLine'][c] else 0 for c in range(i - 20, i)])
|
||||
change_lagging = sum([1 if data['laggingSpan'][c] > data['changeLine'][c] else 0 for c in range(i - 20, i)])
|
||||
|
||||
if lagging_change>10:
|
||||
if lagging_change > 10:
|
||||
return 1
|
||||
if change_lagging==20:
|
||||
if change_lagging == 20:
|
||||
return -1
|
||||
return 0
|
||||
|
||||
@@ -159,8 +164,10 @@ class BuySellChecker:
|
||||
if i > START_TIME_INDEX:
|
||||
# 매도 분석
|
||||
|
||||
if data['changeLine'][i - 1] >= data['laggingSpan'][i - 1] and data['laggingSpan'][i] < data['changeLine'][i]:
|
||||
changeLine_count = sum([1 if data['changeLine'][c] <= data['laggingSpan'][c] else 0 for c in range(i - 20, i)])
|
||||
if data['changeLine'][i - 1] >= data['laggingSpan'][i - 1] and data['laggingSpan'][i] < data['changeLine'][
|
||||
i]:
|
||||
changeLine_count = sum(
|
||||
[1 if data['changeLine'][c] <= data['laggingSpan'][c] else 0 for c in range(i - 20, i)])
|
||||
if changeLine_count >= 17:
|
||||
sell = min(data["open"][i], data["close"][i])
|
||||
weight = 1
|
||||
@@ -225,8 +232,10 @@ class BuySellChecker:
|
||||
if i > START_TIME_INDEX:
|
||||
# 매도 분석
|
||||
|
||||
if data['changeLine'][i - 1] >= data['laggingSpan'][i - 1] and data['laggingSpan'][i] < data['changeLine'][i]:
|
||||
changeLine_count = sum([1 if data['changeLine'][c] <= data['laggingSpan'][c] else 0 for c in range(i - 20, i)])
|
||||
if data['changeLine'][i - 1] >= data['laggingSpan'][i - 1] and data['laggingSpan'][i] < data['changeLine'][
|
||||
i]:
|
||||
changeLine_count = sum(
|
||||
[1 if data['changeLine'][c] <= data['laggingSpan'][c] else 0 for c in range(i - 20, i)])
|
||||
if changeLine_count >= 17:
|
||||
sell = min(data["open"][i], data["close"][i])
|
||||
weight = 1
|
||||
@@ -273,8 +282,8 @@ class BuySellChecker:
|
||||
df = pd.DataFrame(close)
|
||||
max20 = df.rolling(window=20).mean()
|
||||
stddev20 = df.rolling(window=20).std()
|
||||
upper_df = max20 + (stddev20 * 2) # 상단 볼린저 밴드
|
||||
lower_df = max20 - (stddev20 * 2) # 하단 볼린저 밴드
|
||||
upper_df = max20 + (stddev20 * 2) # 상단 볼린저 밴드
|
||||
lower_df = max20 - (stddev20 * 2) # 하단 볼린저 밴드
|
||||
|
||||
upper, lower = [], []
|
||||
for i in range(len(upper_df)):
|
||||
@@ -321,13 +330,15 @@ class BuySellChecker:
|
||||
temp = {
|
||||
"date": point_temp,
|
||||
"open": open, "high": high, "low": low, "close": close, "volume": vol,
|
||||
"avg3": avg3,"avg6": avg6,"avg9": avg9,"avg12": avg12, "avg20": avg20,
|
||||
"disparity_avg5": disparity_avg5, "disparity_avg10": disparity_avg10, "disparity_avg20": disparity_avg20, "disparity_avg60": disparity_avg60, "disparity_avg120": disparity_avg120,
|
||||
"avg3": avg3, "avg6": avg6, "avg9": avg9, "avg12": avg12, "avg20": avg20,
|
||||
"disparity_avg5": disparity_avg5, "disparity_avg10": disparity_avg10, "disparity_avg20": disparity_avg20,
|
||||
"disparity_avg60": disparity_avg60, "disparity_avg120": disparity_avg120,
|
||||
"upper": upper, "lower": lower,
|
||||
"macd": macd, "macds": macds, "macdo": macdo,
|
||||
"fast_k": fast_k, "slow_k": slow_k, "slow_d": slow_d,
|
||||
"rsi": rsi, "rsis": rsis,
|
||||
"changeLine": changeLine, "baseLine": baseLine, "laggingSpan": laggingSpan, "leadingSpan1": leadingSpan1, "leadingSpan2": leadingSpan2,
|
||||
"changeLine": changeLine, "baseLine": baseLine, "laggingSpan": laggingSpan, "leadingSpan1": leadingSpan1,
|
||||
"leadingSpan2": leadingSpan2,
|
||||
|
||||
"label": label
|
||||
}
|
||||
@@ -368,9 +379,15 @@ class BuySellChecker:
|
||||
avg54_list = close_df.rolling(window=54).mean().fillna(close[0]).values.tolist()
|
||||
avg54 = [item[0] for item in avg54_list]
|
||||
|
||||
abs_avg_1 = [max(avg3[i], avg6[i], avg9[i], avg12[i], avg27[i], avg54[i]) - min(avg3[i], avg6[i], avg9[i], avg12[i], avg27[i], avg54[i]) for i in range(0, len(close))]
|
||||
abs_avg_2 = [max(avg3[i], avg6[i], avg9[i], avg12[i], avg27[i]) - min(avg3[i], avg6[i], avg9[i], avg12[i], avg27[i]) for i in range(0, len(close))]
|
||||
abs_avg_3 = [max(avg3[i], avg6[i], avg9[i], avg12[i]) - min(avg3[i], avg6[i], avg9[i], avg12[i]) for i in range(0, len(close))]
|
||||
abs_avg_1 = [
|
||||
max(avg3[i], avg6[i], avg9[i], avg12[i], avg27[i], avg54[i]) - min(avg3[i], avg6[i], avg9[i], avg12[i],
|
||||
avg27[i], avg54[i]) for i in
|
||||
range(0, len(close))]
|
||||
abs_avg_2 = [
|
||||
max(avg3[i], avg6[i], avg9[i], avg12[i], avg27[i]) - min(avg3[i], avg6[i], avg9[i], avg12[i], avg27[i]) for
|
||||
i in range(0, len(close))]
|
||||
abs_avg_3 = [max(avg3[i], avg6[i], avg9[i], avg12[i]) - min(avg3[i], avg6[i], avg9[i], avg12[i]) for i in
|
||||
range(0, len(close))]
|
||||
abs_avg_4 = [max(avg3[i], avg6[i], avg9[i]) - min(avg3[i], avg6[i], avg9[i]) for i in range(0, len(close))]
|
||||
abs_avg_5 = [max(avg3[i], avg6[i]) - min(avg3[i], avg6[i]) for i in range(0, len(close))]
|
||||
|
||||
@@ -391,7 +408,7 @@ class BuySellChecker:
|
||||
diff_avg3, diff_avg6, diff_avg9, diff_avg12, diff_avg27, diff_avg54 = [], [], [], [], [], []
|
||||
diff_avg3.append(0)
|
||||
for i in range(1, len(avg3)):
|
||||
diff_avg3.append(avg3[i]-avg3[i-1])
|
||||
diff_avg3.append(avg3[i] - avg3[i - 1])
|
||||
diff_avg6.append(0)
|
||||
for i in range(1, len(avg6)):
|
||||
diff_avg6.append(avg6[i] - avg6[i - 1])
|
||||
@@ -408,7 +425,6 @@ class BuySellChecker:
|
||||
for i in range(1, len(avg54)):
|
||||
diff_avg54.append(avg54[i] - avg54[i - 1])
|
||||
|
||||
|
||||
diff_avg3_avg6 = [avg3[i] - avg6[i] for i in range(0, len(close))]
|
||||
diff_avg3_avg9 = [avg3[i] - avg9[i] for i in range(0, len(close))]
|
||||
diff_avg3_avg12 = [avg3[i] - avg12[i] for i in range(0, len(close))]
|
||||
@@ -429,8 +445,8 @@ class BuySellChecker:
|
||||
df = pd.DataFrame(close)
|
||||
max20 = df.rolling(window=20).mean()
|
||||
stddev20 = df.rolling(window=20).std()
|
||||
upper_df = max20 + (stddev20 * 2) # 상단 볼린저 밴드
|
||||
lower_df = max20 - (stddev20 * 2) # 하단 볼린저 밴드
|
||||
upper_df = max20 + (stddev20 * 2) # 상단 볼린저 밴드
|
||||
lower_df = max20 - (stddev20 * 2) # 하단 볼린저 밴드
|
||||
|
||||
upper, lower = [], []
|
||||
for i in range(len(upper_df)):
|
||||
@@ -445,7 +461,8 @@ class BuySellChecker:
|
||||
STOCK = []
|
||||
for i in range(len(open)):
|
||||
STOCK.append({'volume': vol[i], 'close': close[i], 'open': open[i], 'high': high[i], 'low': low[i],
|
||||
'avg3': avg3[i], 'avg6': avg6[i],'avg9': avg9[i],'avg12': avg12[i],'avg27': avg27[i],'avg54': avg54[i]})
|
||||
'avg3': avg3[i], 'avg6': avg6[i], 'avg9': avg9[i], 'avg12': avg12[i], 'avg27': avg27[i],
|
||||
'avg54': avg54[i]})
|
||||
|
||||
# stochastic
|
||||
stochastic_df = self.stochastic.apply(STOCK, n=30, m=5, t=5)
|
||||
@@ -484,7 +501,6 @@ class BuySellChecker:
|
||||
diff_low_lower = [low[i] - lower[i] for i in range(0, len(low))]
|
||||
diff_low_upper = [low[i] - upper[i] for i in range(0, len(low))]
|
||||
|
||||
|
||||
##### 일목균형표
|
||||
diff_lead1_lead2 = [leadingSpan1[i] - leadingSpan2[i] for i in range(0, len(leadingSpan1))]
|
||||
diff_change_base = [changeLine[i] - baseLine[i] for i in range(0, len(baseLine))]
|
||||
@@ -512,7 +528,6 @@ class BuySellChecker:
|
||||
diff_slowk_slowd = [slow_k[i] - slow_d[i] for i in range(0, len(slow_k))]
|
||||
diff_rsi_rsis = [rsi[i] - rsis[i] for i in range(0, len(rsi))]
|
||||
|
||||
|
||||
diff_macd, diff_macdo, diff_macds = [], [], []
|
||||
diff_macd.append(0)
|
||||
for i in range(1, len(macd)):
|
||||
@@ -570,14 +585,16 @@ class BuySellChecker:
|
||||
"rsi": rsi, "rsis": rsis,
|
||||
"changeLine": changeLine, "baseLine": baseLine, "leadingSpan1": leadingSpan1, "leadingSpan2": leadingSpan2,
|
||||
"height": height, "top_tail_height": top_tail_height, "bottom_tail_height": bottom_tail_height,
|
||||
"abs_avg_1": abs_avg_1, "abs_avg_2": abs_avg_2, "abs_avg_3": abs_avg_3, "abs_avg_4": abs_avg_4, "abs_avg_5": abs_avg_5,
|
||||
"abs_avg_1": abs_avg_1, "abs_avg_2": abs_avg_2, "abs_avg_3": abs_avg_3, "abs_avg_4": abs_avg_4,
|
||||
"abs_avg_5": abs_avg_5,
|
||||
"diff_open": diff_open, "diff_close": diff_close, "diff_low": diff_low, "diff_high": diff_high,
|
||||
"diff_avg3":diff_avg3, "diff_avg6":diff_avg6, "diff_avg9":diff_avg9, "diff_avg12":diff_avg12, "diff_avg27":diff_avg27, "diff_avg54":diff_avg54,
|
||||
"diff_macd":diff_macd, "diff_macdo":diff_macdo, "diff_macds":diff_macds,
|
||||
"diff_fast_k":diff_fast_k, "diff_slow_k":diff_slow_k, "diff_slow_d":diff_slow_d,
|
||||
"diff_rsi":diff_rsi, "diff_rsis":diff_rsis,
|
||||
"diff_changeLine":diff_changeLine, "diff_baseLine":diff_baseLine,
|
||||
"diff_upper":diff_upper, "diff_lower":diff_lower,
|
||||
"diff_avg3": diff_avg3, "diff_avg6": diff_avg6, "diff_avg9": diff_avg9, "diff_avg12": diff_avg12,
|
||||
"diff_avg27": diff_avg27, "diff_avg54": diff_avg54,
|
||||
"diff_macd": diff_macd, "diff_macdo": diff_macdo, "diff_macds": diff_macds,
|
||||
"diff_fast_k": diff_fast_k, "diff_slow_k": diff_slow_k, "diff_slow_d": diff_slow_d,
|
||||
"diff_rsi": diff_rsi, "diff_rsis": diff_rsis,
|
||||
"diff_changeLine": diff_changeLine, "diff_baseLine": diff_baseLine,
|
||||
"diff_upper": diff_upper, "diff_lower": diff_lower,
|
||||
"diff_avg3_avg6": diff_avg3_avg6,
|
||||
"diff_avg3_avg9": diff_avg3_avg9,
|
||||
"diff_avg3_avg12": diff_avg3_avg12,
|
||||
@@ -790,7 +807,6 @@ class BuySellChecker:
|
||||
|
||||
return bsLine, data
|
||||
|
||||
|
||||
def checkTransactionML(self, data, stock_code, predY, isRealTime=True):
|
||||
# 4일치 중에서 앞에 2일은 제거한다.
|
||||
date = data['date'].dt.date.unique().tolist()
|
||||
@@ -841,88 +857,68 @@ class BuySellChecker:
|
||||
|
||||
|
||||
|
||||
# middle line에 맞다은 적 없이, low line에 붙었거나 아래에 있었던 캔들의 높은 가격을 얻어옴
|
||||
def getPrice_UnderLowWithoutMiddle(self, last_index, data):
|
||||
if data['high'][last_index] < data['envelope_middle'][last_index]:
|
||||
for i in range(last_index - 1, 0, -1):
|
||||
if data['high'][i] > data['envelope_middle'][i]:
|
||||
return -1, -1
|
||||
if data['low'][i] < data['envelope_lower'][i]:
|
||||
return i, max(data['open'][i], data['close'][i])
|
||||
return -1, -1
|
||||
|
||||
def getBuyPriceAndWeight_Envelope_trend(self, data, i):
|
||||
buy, weight, type = -1, -1, -1
|
||||
def getBuyPriceAndWeight_Envelope(self, i, data):
|
||||
buy, weight = -1, -1
|
||||
|
||||
if data['close'][i-1] < data['envelope_lower'][i-1] and data['envelope_lower'][i] < data['close'][i]:
|
||||
buy = data["close"][i]
|
||||
weight = 1
|
||||
type = 1
|
||||
"""
|
||||
# middle line에 맞다은 적 없이, low line에 붙었거나 아래에 있었던 캔들의 높은 가격을 얻어옴
|
||||
index, price = self.getPrice_UnderLowWithoutMiddle(i, data)
|
||||
if price > -1:
|
||||
# 해당 가격보다 높은 가격이면 매수한다
|
||||
if price < data['close'][i]:
|
||||
buy = data['close'][i]
|
||||
weight = 10
|
||||
"""
|
||||
if i > 100:
|
||||
if -0.004 < data['gradient1'][i] < 0.001:
|
||||
#if data['high'][i] < data['envelope_middle'][i]:
|
||||
if data['slow_k'][i] < 20:
|
||||
buy = data['close'][i]
|
||||
weight = 10
|
||||
|
||||
if data['close'][i] < data['envelope_lower'][i]:
|
||||
if data['rsis'][i] < data['rsi'][i]:
|
||||
buy = data["close"][i]
|
||||
weight = 1
|
||||
type = 2
|
||||
"""
|
||||
if i > 100:
|
||||
if min(data['gradient1'][i-5:i]) < -0.009 and -0.009 < data['gradient1'][i]:
|
||||
if data['high'][i] < data['envelope_middle'][i]:
|
||||
buy = data['close'][i]
|
||||
weight = 10
|
||||
"""
|
||||
return buy, weight
|
||||
|
||||
if data['close'][i-1] < data['envelope_middle'][i-1] and data['envelope_middle'][i] < data['close'][i]:
|
||||
if data['slow_k'][i] < 25:
|
||||
buy = data["close"][i]
|
||||
weight = 1
|
||||
type = 3
|
||||
|
||||
check1 = False
|
||||
check2 = False
|
||||
if data['slow_k'][i] < 40:
|
||||
if data['close'][i-1] < data['envelope_middle'][i-1] and data['envelope_middle'][i] < data['close'][i]:
|
||||
idx = -1
|
||||
for t1 in range(i-1, i-10, -1):
|
||||
if data['close'][t1] < data['envelope_middle'][t1]:
|
||||
check1 = True
|
||||
idx = t1
|
||||
break
|
||||
if check1:
|
||||
for t1 in range(idx-1, i - 10, -1):
|
||||
if data['envelope_middle'][t1] < data['close'][t1]:
|
||||
check2 = True
|
||||
break
|
||||
if check2:
|
||||
buy = data["close"][i]
|
||||
weight = 1
|
||||
type = 4
|
||||
|
||||
if data.index[i].strftime("%Y.%m.%d") == "2021.12.21":
|
||||
print(1)
|
||||
|
||||
check = True
|
||||
if data['slow_k'][i] < 40:
|
||||
if data['close'][i - 1] < data['envelope_middle'][i - 1] and data['envelope_middle'][i] < data['close'][i]:
|
||||
|
||||
for t1 in range(i-1, i-10, -1):
|
||||
if data['envelope_middle'][t1] < data['close'][t1]:
|
||||
check = False
|
||||
if check:
|
||||
buy = data["close"][i]
|
||||
weight = 1
|
||||
type = 4
|
||||
|
||||
return buy, weight, type
|
||||
|
||||
def getSellPriceAndWeight_Envelope_trend(self, data, i):
|
||||
def getSellPriceAndWeight_Envelope(self, data, i):
|
||||
sell, weight, type = -1, -1, -1
|
||||
|
||||
if data.index[i].strftime("%Y.%m.%d") == "2022.12.01":
|
||||
print (1)
|
||||
print(1)
|
||||
|
||||
# upper lined에서 처리
|
||||
if data['close'][i-1] < data['envelope_upper'][i - 1] and data['envelope_upper'][i] < data['close'][i]:
|
||||
if data['slow_d'][i-1] <= data['slow_k'][i - 1] and data['slow_k'][i] <= data['slow_d'][i]:
|
||||
if data['close'][i - 1] < data['envelope_upper'][i - 1] and data['envelope_upper'][i] < data['close'][i]:
|
||||
if data['slow_d'][i - 1] <= data['slow_k'][i - 1] and data['slow_k'][i] <= data['slow_d'][i]:
|
||||
sell = data["close"][i]
|
||||
weight = 1
|
||||
type = 1
|
||||
if data['envelope_upper'][i-1] < data['close'][i - 1] and data['envelope_upper'][i] < data['close'][i]:
|
||||
if data['slow_d'][i-1] <= data['slow_k'][i - 1] and data['slow_k'][i] <= data['slow_d'][i]:
|
||||
if data['envelope_upper'][i - 1] < data['close'][i - 1] and data['envelope_upper'][i] < data['close'][i]:
|
||||
if data['slow_d'][i - 1] <= data['slow_k'][i - 1] and data['slow_k'][i] <= data['slow_d'][i]:
|
||||
sell = data["close"][i]
|
||||
weight = 1
|
||||
type = 2
|
||||
if data['envelope_upper'][i-1] < data['close'][i - 1] and data['envelope_upper'][i] < data['close'][i]:
|
||||
if data['slow_d'][i-1] +2 <= data['slow_k'][i - 1] and data['slow_d'][i]+1 == data['slow_k'][i]:
|
||||
if data['envelope_upper'][i - 1] < data['close'][i - 1] and data['envelope_upper'][i] < data['close'][i]:
|
||||
if data['slow_d'][i - 1] + 2 <= data['slow_k'][i - 1] and data['slow_d'][i] + 1 == data['slow_k'][i]:
|
||||
sell = data["close"][i]
|
||||
weight = 1
|
||||
type = 3
|
||||
|
||||
if data['envelope_upper'][i]<data['high'][i] and data['open'][i] < data['close'][i]:
|
||||
if data['envelope_upper'][i] < data['high'][i] and data['open'][i] < data['close'][i]:
|
||||
if data['close'][i] - data['open'][i] < data['high'][i] - data['close'][i]:
|
||||
sell = data["close"][i]
|
||||
weight = 1
|
||||
@@ -930,109 +926,303 @@ class BuySellChecker:
|
||||
|
||||
return sell, weight, type
|
||||
|
||||
def getBuyPriceAndWeight_Envelope(self, data, i):
|
||||
buy, weight, type = -1, -1, -1
|
||||
# 팔아야 할 시점을 체크하기 위함
|
||||
# 이전에 산 가격보다 지금 5원이상 떨어졌다면 매도 한다.
|
||||
def checkBelow5WonFromPreviousBuyPrice(self, last_index, data, price):
|
||||
for i in range(last_index - 1, 0, -1):
|
||||
if data['sell'][i] != -1:
|
||||
return False
|
||||
if data['buy'][i] != -1:
|
||||
if data['buy'][i] - price > 5:
|
||||
return True
|
||||
return
|
||||
|
||||
if data['close'][i-1] < data['envelope_lower'][i-1] and data['envelope_lower'][i] < data['close'][i]:
|
||||
buy = data["close"][i]
|
||||
weight = 1
|
||||
type = 1
|
||||
def checkWithEnvelope_252670(self, data, isRealTime=False):
|
||||
|
||||
if data['close'][i] < data['envelope_lower'][i]:
|
||||
if data['rsis'][i] < data['rsi'][i]:
|
||||
buy = data["close"][i]
|
||||
weight = 1
|
||||
type = 2
|
||||
|
||||
return buy, weight, type
|
||||
|
||||
def getSellPriceAndWeight_Envelope(self, data, i):
|
||||
sell, weight, type = -1, -1, -1
|
||||
|
||||
if data.index[i].strftime("%Y.%m.%d") == "2022.12.01":
|
||||
print (1)
|
||||
|
||||
# upper lined에서 처리
|
||||
if data['close'][i-1] < data['envelope_upper'][i - 1] and data['envelope_upper'][i] < data['close'][i]:
|
||||
if data['slow_d'][i-1] <= data['slow_k'][i - 1] and data['slow_k'][i] <= data['slow_d'][i]:
|
||||
sell = data["close"][i]
|
||||
weight = 1
|
||||
type = 1
|
||||
if data['envelope_upper'][i-1] < data['close'][i - 1] and data['envelope_upper'][i] < data['close'][i]:
|
||||
if data['slow_d'][i-1] <= data['slow_k'][i - 1] and data['slow_k'][i] <= data['slow_d'][i]:
|
||||
sell = data["close"][i]
|
||||
weight = 1
|
||||
type = 2
|
||||
if data['envelope_upper'][i-1] < data['close'][i - 1] and data['envelope_upper'][i] < data['close'][i]:
|
||||
if data['slow_d'][i-1] +2 <= data['slow_k'][i - 1] and data['slow_d'][i]+1 == data['slow_k'][i]:
|
||||
sell = data["close"][i]
|
||||
weight = 1
|
||||
type = 3
|
||||
|
||||
# middle lined에서 처리
|
||||
middle_up = False
|
||||
if data['envelope_middle'][i-1] < data['close'][i-1] or data['envelope_middle'][i] < data['open'][i]:
|
||||
if data['envelope_middle'][i-2] < data['close'][i-2] or data['envelope_middle'][i-1] < data['close'][i-1] or data['envelope_middle'][i] < data['close'][i]:
|
||||
for t in range(i-1, i-20, -1):
|
||||
if data['envelope_upper'][t] <= data['close'][t]:
|
||||
middle_up = False
|
||||
break
|
||||
if data['close'][t] < data['envelope_middle'][t]:
|
||||
middle_up = True
|
||||
break
|
||||
|
||||
if middle_up:
|
||||
if data['slow_d'][i-1] < data['slow_k'][i-1] and data['slow_k'][i] < data['slow_d'][i]:
|
||||
sell = data["close"][i]
|
||||
weight = 1
|
||||
type = 4
|
||||
|
||||
|
||||
return sell, weight, type
|
||||
|
||||
def checkEnvelopeTiming(self, data, stock_code, isRealTime=True):
|
||||
# 어제 오늘 데이터로 분석
|
||||
bsLine = {}
|
||||
size = len(data["close"])
|
||||
|
||||
if isRealTime:
|
||||
# isRealTime=True, 실시간 적용
|
||||
last_index = size - 1
|
||||
bsLine['buy'] = [-1 for i in range(size)]
|
||||
bsLine['buy_weight'] = [-1 for i in range(size)]
|
||||
bsLine['sell'] = [-1 for i in range(size)]
|
||||
bsLine['sell_weight'] = [-1 for i in range(size)]
|
||||
|
||||
if stock_code == "252670":
|
||||
buy, buy_weight, buy_type = self.getBuyPriceAndWeight_Envelope(data, last_index)
|
||||
sell, sell_weight, sell_type = self.getSellPriceAndWeight_Envelope(data, last_index)
|
||||
else:
|
||||
buy, buy_weight, buy_type = self.getBuyPriceAndWeight_Envelope(data, last_index)
|
||||
sell, sell_weight, sell_type = self.getSellPriceAndWeight_Envelope(data, last_index)
|
||||
for i in range(size):
|
||||
if isRealTime:
|
||||
if i < size - 1:
|
||||
continue
|
||||
|
||||
bsLine['buy'] = [buy]
|
||||
bsLine['buy_weight'] = [buy_weight]
|
||||
bsLine['sell'] = [sell]
|
||||
bsLine['sell_weight'] = [sell_weight]
|
||||
"""
|
||||
# 이전에 산 가격보다 지금 5원이상 떨어졌다면 매도 한다.
|
||||
price = data['close'][i] if data['close'][i] >= data['open'][i] else data['open'][i]
|
||||
if self.checkBelow5WonFromPreviousBuyPrice(i, data, price):
|
||||
data['sell'][i] = price
|
||||
bsLine['sell'][i] = price
|
||||
bsLine['sell_weight'][i] = 50
|
||||
return bsLine, data
|
||||
"""
|
||||
|
||||
else:
|
||||
# Type=False, 시뮬레이션 적용
|
||||
bsLine['buy'] = [-1 for i in range(size)]
|
||||
bsLine['buy_weight'] = [-1 for i in range(size)]
|
||||
bsLine['sell'] = [-1 for i in range(size)]
|
||||
bsLine['sell_weight'] = [-1 for i in range(size)]
|
||||
"""
|
||||
# middle line에 맞다은 적 없이, low line에 붙었거나 아래에 있었던 캔들의 높은 가격을 얻어옴
|
||||
buy, buy_weight = self.getBuyPriceAndWeight_Envelope(i, data)
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = buy_weight
|
||||
return bsLine, data
|
||||
"""
|
||||
|
||||
for i in range(size):
|
||||
if stock_code == "252670":
|
||||
buy, buy_weight, buy_type = self.getBuyPriceAndWeight_Envelope_trend(data, i)
|
||||
sell, sell_weight, sell_type = self.getSellPriceAndWeight_Envelope_trend(data, i)
|
||||
else:
|
||||
buy, buy_weight, buy_type = self.getBuyPriceAndWeight_Envelope(data, i)
|
||||
sell, sell_weight, sell_type = self.getSellPriceAndWeight_Envelope(data, i)
|
||||
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = buy_weight
|
||||
bsLine['sell'][i] = sell
|
||||
bsLine['sell_weight'][i] = sell_weight
|
||||
if i > 0:
|
||||
if bsLine['sell'][i-1] > -1:
|
||||
bsLine['sell'][i] = -1
|
||||
bsLine['sell_weight'][i] = -1
|
||||
if 0 < data['gradients_avg60'][i] < 0.001:
|
||||
if data['high'][i] < data['envelope_middle'][i]:
|
||||
if -0.015 < data['gradients_avg5'][i] and -0.007 < data['gradients_avg20'][i]:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 10
|
||||
|
||||
if i > 10:
|
||||
if (
|
||||
data['gradients_avg60'][i - 10] > 0 and data['gradients_avg60'][i - 9] > 0 and data['gradients_avg60'][i - 8] > 0 and
|
||||
data['gradients_avg60'][i - 7] > 0 and data['gradients_avg60'][i - 6] > 0 and data['gradients_avg60'][i - 5] > 0 and
|
||||
data['gradients_avg60'][i - 4] > 0 and data['gradients_avg60'][i - 3] > 0 and data['gradients_avg60'][i - 2] > 0 and
|
||||
data['gradients_avg60'][i - 1] > 0 and data['gradients_avg60'][i] < 0
|
||||
):
|
||||
if data['disparity'][i] < 3:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 10
|
||||
|
||||
if i > 10:
|
||||
if data['disparity_avg60'][i] < 65:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 20
|
||||
|
||||
if data['slow_k'][i] < 3:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 10
|
||||
|
||||
return bsLine, data
|
||||
|
||||
|
||||
def checkWithEnvelope_122630(self, data, isRealTime=False):
|
||||
|
||||
bsLine = {}
|
||||
size = len(data["close"])
|
||||
|
||||
bsLine['buy'] = [-1 for i in range(size)]
|
||||
bsLine['buy_weight'] = [-1 for i in range(size)]
|
||||
bsLine['sell'] = [-1 for i in range(size)]
|
||||
bsLine['sell_weight'] = [-1 for i in range(size)]
|
||||
|
||||
for i in range(size):
|
||||
if isRealTime:
|
||||
if i < size - 1:
|
||||
continue
|
||||
|
||||
if i > 10:
|
||||
if data['disparity_avg60'][i] < 60:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 20
|
||||
|
||||
if data['macd'][i] < -1000:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 20
|
||||
|
||||
if data['slow_k'][i] < 7:
|
||||
if data['slow_d'][i] < data['slow_k'][i]:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 5
|
||||
|
||||
return bsLine, data
|
||||
|
||||
def notBuy(self, data, i):
|
||||
if i > 5:
|
||||
check = True
|
||||
for l in range(i-4, i+1):
|
||||
if (
|
||||
data['gradients_avg60'][l - 1] > data['gradients_avg60'][l] or
|
||||
data['gradients_avg20'][l - 1] > data['gradients_avg20'][l] or
|
||||
data['gradients_low'][l - 1] > data['gradients_low'][l]
|
||||
):
|
||||
check = False
|
||||
break
|
||||
if not check:
|
||||
return False
|
||||
return True
|
||||
|
||||
def checkWithEnvelope(self, data, isRealTime=False):
|
||||
|
||||
bsLine = {}
|
||||
size = len(data["close"])
|
||||
|
||||
bsLine['buy'] = [-1 for i in range(size)]
|
||||
bsLine['buy_weight'] = [-1 for i in range(size)]
|
||||
bsLine['sell'] = [-1 for i in range(size)]
|
||||
bsLine['sell_weight'] = [-1 for i in range(size)]
|
||||
|
||||
for i in range(size):
|
||||
if isRealTime:
|
||||
if i < size - 1:
|
||||
continue
|
||||
|
||||
if i > 10:
|
||||
if data['disparity'][i] < 2:
|
||||
check = True
|
||||
for l in range(i-3, i):
|
||||
if (
|
||||
data['gradients_avg60'][l-1] > data['gradients_avg60'][l] or
|
||||
data['gradients_avg20'][l-1] > data['gradients_avg20'][l] or
|
||||
data['gradients_low'][l-1] > data['gradients_low'][l] or
|
||||
data['disparity_avg5'][l-1] > data['disparity_avg5'][l] or
|
||||
data['disparity'][l-1] < data['disparity'][l]
|
||||
):
|
||||
check = False
|
||||
break
|
||||
if check and 99 < sum(data['disparity_avg5'][i-4:i+1])/5 < 100 and 99 < sum(data['disparity_avg60'][i-4:i+1])/5 < 100:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 20
|
||||
|
||||
check = True
|
||||
for l in range(i - 2, i):
|
||||
if (
|
||||
data['gradients_avg60'][l - 1] > data['gradients_avg60'][l] or
|
||||
data['gradients_low'][l - 1] > data['gradients_low'][l]
|
||||
):
|
||||
check = False
|
||||
break
|
||||
if (
|
||||
check and
|
||||
-0.0011 < data['gradients_low'][i] < 0 and -0.007 < data['gradients_avg5'][i] < 0.001 and
|
||||
-0.0012 < data['gradients_avg60'][i] < 0 and
|
||||
98.90 < data['disparity_avg5'][i] < 101
|
||||
):
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 20
|
||||
|
||||
check = True
|
||||
for l in range(i - 6, i):
|
||||
if (
|
||||
data['gradients_avg60'][l - 1] < data['gradients_avg60'][l] or
|
||||
data['gradients_avg20'][l - 1] < data['gradients_avg20'][l] or
|
||||
data['gradients_low'][l - 1] < data['gradients_low'][l] or
|
||||
-0.039 < data['gradients_low'][l - 1] < -0.35 or
|
||||
-0.05 < data['gradients_avg20'][l - 1] < -0.30 or
|
||||
-0.40 < data['gradients_avg60'][l - 1] < -0.30
|
||||
):
|
||||
check = False
|
||||
break
|
||||
if check and 99 < min (data['disparity_avg5'][i - 6:i]) < max (data['disparity_avg5'][i - 6:i]) < 101:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 20
|
||||
|
||||
check = True
|
||||
for l in range(i - 3, i):
|
||||
if (
|
||||
data['gradients_low'][l - 1] < data['gradients_low'][l] or
|
||||
data['gradients_avg60'][l - 1] < data['gradients_avg60'][l] or
|
||||
data['gradients_avg20'][l - 1] < data['gradients_avg20'][l] or
|
||||
0.01 < data['gradients_low'][l - 1] < 0.21 or
|
||||
-0.09 < data['gradients_avg20'][l - 1] < -0.002 or
|
||||
0.01 < data['gradients_avg60'][l - 1] < 0.021
|
||||
):
|
||||
check = False
|
||||
break
|
||||
if check:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 20
|
||||
|
||||
|
||||
if (data['disparity'][i] < 5 and 99.0 < data['disparity_avg60'][i] < 99.1 and
|
||||
-0.009 < data['gradients_avg60'][i] < -0.008 and 0.015 < data['gradients_avg20'][i] < 0.016 and
|
||||
-0.006 < data['gradients_avg5'][i] < -0.005 and -0.009 < data['gradients_low'][i] < -0.008):
|
||||
check = True
|
||||
for l in range(i-5, i):
|
||||
if (
|
||||
data['gradients_avg60'][l-1] > data['gradients_avg60'][l] or
|
||||
data['gradients_low'][l-1] > data['gradients_low'][l] or
|
||||
data['disparity'][l - 1] < data['disparity'][l]
|
||||
):
|
||||
check = False
|
||||
break
|
||||
if check:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 20
|
||||
|
||||
if data['macd'][i] < -4000:
|
||||
if data['macd'][i-1] < data['macd'][i]:
|
||||
if not self.notBuy(data, i) and data['slow_k'][i] < 30:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 20
|
||||
|
||||
# macd 이전에 없던 바닥인 경우 상승할 찰나 매수
|
||||
if data['macds'][i-1] < min(data['macds'][:i-1]):
|
||||
if data['macds'][i-1] < data['macds'][i]:
|
||||
if not self.notBuy(data, i) and data['slow_k'][i] < 30:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 20
|
||||
|
||||
if (
|
||||
98 < data['disparity_avg5'][i] < 100 and data['disparity_avg20'][i] < 93.5 and data['disparity_avg60'][i] < 89 and
|
||||
-0.014 < data['gradients_avg60'][i] < -0.013 and -0.03 < data['gradients_avg20'][i] < -0.02 and -0.014 < data['gradients_low'][i] < -0.013 and
|
||||
data['slow_k'][i] < 11
|
||||
):
|
||||
if not self.notBuy(data, i):
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 20
|
||||
|
||||
|
||||
"""
|
||||
if data['disparity_avg60'][i] < 60:
|
||||
buy = data['low'][i]
|
||||
data['buy'][i] = buy
|
||||
bsLine['buy'][i] = buy
|
||||
bsLine['buy_weight'][i] = 20
|
||||
"""
|
||||
|
||||
return bsLine, data
|
||||
|
||||
def checkTransactionWithEnvelope(self, data, stock_code, isRealTime=False):
|
||||
if isRealTime:
|
||||
if stock_code == "252670":
|
||||
bsLine, data = self.checkWithEnvelope_252670(data, isRealTime)
|
||||
elif stock_code == "122630":
|
||||
bsLine, data = self.checkWithEnvelope_122630(data, isRealTime)
|
||||
else:
|
||||
bsLine, data = self.checkWithEnvelope(data, isRealTime)
|
||||
else:
|
||||
# 사야 할 시점과 팔아야 할 시점을 체크한다.
|
||||
if stock_code == "252670":
|
||||
bsLine, data = self.checkWithEnvelope_252670(data, isRealTime)
|
||||
elif stock_code == "122630":
|
||||
bsLine, data = self.checkWithEnvelope_122630(data, isRealTime)
|
||||
else:
|
||||
bsLine, data = self.checkWithEnvelope(data, isRealTime)
|
||||
|
||||
return bsLine, data
|
||||
Reference in New Issue
Block a user