Administrator
9 天以前 622d2ebab2f86482e84a54e36dce09dc6162e613
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
"""
首板目标代码处理器
"""
 
# 处理首板代码信息
 
import constant
from code_attribute import gpcode_manager, gpcode_first_screen_manager, code_nature_analyse, \
    code_volumn_manager
from code_attribute.code_data_util import ZYLTGBUtil
from code_attribute.code_nature_analyse import HighIncreaseCodeManager
from code_attribute.gpcode_manager import WantBuyCodesManager
from log_module import async_log_util
from log_module.log import logger_first_code_record, logger_l2_codes_subscript, logger_debug
from third_data import history_k_data_manager
from third_data.code_plate_key_manager import CodesHisReasonAndBlocksManager
from third_data.history_k_data_manager import HistoryKDataManager
from third_data.history_k_data_util import HistoryKDatasUtils, JueJinApi
from trade import l2_trade_util
from settings.trade_setting import MarketSituationManager
from trade.buy_radical import new_block_processor
from trade.buy_radical.block_special_codes_manager import BlockSpecialCodesManager
from utils import global_util, tool, init_data_util, buy_condition_util
 
__CodesPlateKeysManager = CodesHisReasonAndBlocksManager()
 
 
def __is_normal_in_5d(code):
    """
    最近5天是否处于正常状态
    @param code:
    @return:
    """
    now_day = tool.get_now_date_str()
    results = JueJinApi.get_history_instruments(JueJinApi.get_juejin_code_list_with_prefix([code]),
                                                tool.date_sub(now_day, 30), tool.date_sub(now_day, 1))
    results = results[-5:]
    normal = True
    for r in results:
        if r["sec_level"] != 1:
            normal = False
            break
    return normal
 
 
def process_first_codes_datas(dataList, request_id=None):
    async_log_util.info(logger_l2_codes_subscript, f"{request_id}加载l2代码相关数据")
    # 获取最近5天的交易日期,为后面的数据计算做准备
    dates = HistoryKDatasUtils.get_latest_trading_date_cache(5)
    latest_trading_date = None
    if dates:
        latest_trading_date = dates[0]
 
    limit_up_price_dict = {}
    temp_codes = []
    codes = []
    tick_datas = []
    if dataList:
        for data in dataList:
            code = data["code"]
            codes.append(code)
 
    # ---查询想买单,如果没有在列表中就需要强行加入列表
    want_codes = gpcode_manager.WantBuyCodesManager().list_code_cache()
    if want_codes:
        # 没有在现价采集中的想买代码
        diff_codes = set(want_codes) - set(codes)
        if diff_codes:
            # 想买单的代码还没有在目标代码中
            for code in diff_codes:
                # 获取涨停价
                _limit_up_price = gpcode_manager.get_limit_up_price(code)
                if not _limit_up_price:
                    history_k_data_manager.re_set_price_pres([code], True)
                    # 再次获取涨停价
                    _limit_up_price = gpcode_manager.get_limit_up_price(code)
                if _limit_up_price:
                    # 成功获取到了涨停价,构造虚拟的现价信息
                    codes.append(code)
                    dataList.append({"code": code, "price": f"{_limit_up_price}", "volume": "0",
                                     "volumeUnit": 0, "time": "00:00:00", "zyltgb": "100",
                                     "zyltgbUnit": 0})
    # 获取昨日收盘价
    need_get_limit_up_codes = set()
    for code in codes:
        # 如果涨停价是空值就需要设置昨日收盘价格
        if gpcode_manager.get_limit_up_price(code) is None:
            need_get_limit_up_codes.add(code)
    if need_get_limit_up_codes:
        history_k_data_manager.re_set_price_pres(list(need_get_limit_up_codes), True)
    logger_l2_codes_subscript.info(f"{request_id}加载l2代码涨停价结束")
    # 获取60天最大记录
    for code in codes:
        need_get_volumn = False
        if code not in global_util.max60_volumn or global_util.max60_volumn.get(
                code) is None or code_nature_analyse.CodeNatureRecordManager().get_k_format_cache(code) is None:
            need_get_volumn = True
        # if not need_get_volumn and code_nature_analyse.CodeNatureRecordManager.get_nature_cache(
        #         code) is None:
        #     need_get_volumn = True
        if need_get_volumn:
            limit_up_price = gpcode_manager.get_limit_up_price(code)
            if limit_up_price is None:
                continue
            try:
                # 首先从缓存里面获取
                volumes_data = None
                if latest_trading_date:
                    volumes_data = HistoryKDataManager().get_history_bars(code, latest_trading_date)
                if not volumes_data:
                    volumes_data = init_data_util.get_volumns_by_code(code, 150)
                    async_log_util.info(logger_l2_codes_subscript, f"{request_id}从网络加载K线数据:{code}")
                if not volumes_data:
                    continue
                volumes = init_data_util.parse_max_volume_new(code, volumes_data[:60])
                max_volume_in_5_days = init_data_util.parse_max_volume_in_days(volumes_data, 5)
 
                async_log_util.info(logger_first_code_record, f"{code} 获取到首板60天最大量:{volumes}")
                code_volumn_manager.CodeVolumeManager().set_histry_volumn(code, volumes[0], volumes[1], volumes[2],
                                                                          volumes[3], max_volume_in_5_days)
 
                # 保存K线形态
                k_format = code_nature_analyse.get_k_format(code, limit_up_price, volumes_data)
                code_nature_analyse.CodeNatureRecordManager().save_k_format(code, k_format)
 
                if not WantBuyCodesManager().is_in_cache(
                        code) and not gpcode_manager.BuyOpenLimitUpCodeManager().is_in_cache(code):
                    # 新题材破前高就不需要加黑
                    # 新题材该拉黑还是拉黑
                    need_forbidden = True  #new_block_processor.is_can_forbidden(code)
                    if need_forbidden:
                        if code_nature_analyse.is_price_too_high_in_days(code, volumes_data, limit_up_price)[0]:
                            # 判断是否太高
                            l2_trade_util.forbidden_trade(code, "6天内股价长得太高")
                            continue
 
                        if tool.is_ge_code(code) and float(limit_up_price) < 10:
                            l2_trade_util.forbidden_trade(code, "创业板股价10块内")
                            continue
 
                        if len(k_format) > 14 and k_format[14]:
                            l2_trade_util.forbidden_trade(code, "上个交易日涨停/炸板")
                            continue
 
                        if len(k_format) > 15 and k_format[15]:
                            l2_trade_util.forbidden_trade(code, "上个交易日跌停")
                            continue
 
                        if len(k_format) > 12 and k_format[12]:
                            l2_trade_util.forbidden_trade(code, "上个交易日振幅过大")
                            continue
 
                        # if code_nature_analyse.is_continue_limit_up_not_enough_fall_dwon(code, volumes_data):
                        #     # 判断是否太高
                        #     l2_trade_util.forbidden_trade(code, "回踩不够")
                        #     continue
                        try:
                            if not __is_normal_in_5d(code):
                                l2_trade_util.forbidden_trade(code, "最近5天有ST/非正常状态")
                                continue
                        except Exception as e:
                            logger_debug.error(f"{code}出错__is_normal_in_5d")
                            logger_debug.exception(e)
 
                if code_nature_analyse.is_up_too_high_in_10d_with_limit_up(code, volumes_data):
                    # 判断是否太高
                    HighIncreaseCodeManager().add_code(code)
 
                if code_nature_analyse.is_up_too_high_in_120d(code, volumes_data):
                    # 判断是否太高
                    # l2_trade_util.forbidden_trade(code, "120天内股价长得太高")
                    # HighIncreaseCodeManager().add_code(code)
                    pass
 
                if code_nature_analyse.is_have_latest_max_volume(code, volumes_data, 2):
                    # 最近2天是否是最高量
                    code_nature_analyse.LatestMaxVolumeManager().set_has_latest_max_volume(code)
 
                # 判断K线形态
                # is_has_k_format, msg = code_nature_analyse.is_has_k_format(
                #     gpcode_manager.get_limit_up_price(code), volumes_data)
                # if not is_has_k_format:
                #     logger_first_code_record.info("{}首板K线形态不好,{}", code, msg)
                #     # 股性不好,就不要加入
                #     bad_codes.add(code)
                #     # 加入禁止交易代码
                #     l2_trade_util.forbidden_trade(code)
                # 暂时不保存K线形态
                # code_nature_analyse.set_record_datas(code,
                #                                      gpcode_manager.get_limit_up_price(code),
                #                                      volumes_data)
            except Exception as e:
                logger_first_code_record.error(f"{request_id}-{code}:{str(e)}")
                logger_first_code_record.exception(e)
 
    async_log_util.info(logger_l2_codes_subscript, f"{request_id}加载l2代码K线结束")
 
    gpcode_manager.FirstCodeManager().add_record(codes)
    # 初始化板块信息,暂时删除
    # for code in codes:
    #     block_info.init_code(code)
    # 保存现价
    if dataList:
        situation = MarketSituationManager().get_situation_cache()
        zyltgb_thresholds = buy_condition_util.get_zyltgb_threshold(situation)
        want_codes = gpcode_manager.WantBuyCodesManager().list_code_cache()
        for data in dataList:
            code = data["code"]
            codes.append(code)
            limit_up_price = gpcode_manager.get_limit_up_price(code)
            if limit_up_price is not None:
                limit_up_price_dict[code] = limit_up_price
            else:
                temp_codes.append(code)
            # 自由流通市值不符合标准
            if not want_codes or code not in want_codes:
                # 没在想买单
                zyltgb = global_util.zyltgb_map.get(code)
                if zyltgb:
                    zyltgb_as_yi = round(zyltgb / 100000000, 2)
                    if zyltgb_as_yi < zyltgb_thresholds[0] or zyltgb_as_yi > zyltgb_thresholds[6]:
                        # 想买单中的不能排除
                        continue
                    elif zyltgb_as_yi > zyltgb_thresholds[1]:
                        # 比最大可买大的,如果没有短期辨识度就不买
                        k_format = code_nature_analyse.CodeNatureRecordManager().get_k_format_cache(code)
                        if k_format and k_format[8][0] and k_format[8][1].find("短期") >= 0:
                            pass
                        else:
                            # 无短期辨识度
                            continue
 
            tick_datas.append({"code": code, "price": data["price"], "volume": data["volume"],
                               "volumeUnit": data["volumeUnit"]})
    # 获取涨停价
    if temp_codes:
        # 获取涨停价
        history_k_data_manager.re_set_price_pres(temp_codes)
        # 重新获取涨停价
        for code in temp_codes:
            limit_up_price = gpcode_manager.get_limit_up_price(code)
            if limit_up_price is not None:
                limit_up_price_dict[code] = limit_up_price
 
    # 首板数据加工
    prices = []
    for data in dataList:
        code = data["code"]
        price = data["price"]
        limit_up_time = data["time"]
        if limit_up_time == "00:00:00":
            limit_up_time = None
        if code not in limit_up_price_dict:
            continue
        is_limit_up = abs(float(limit_up_price_dict[code]) - float(price)) < 0.001
        # 纠正数据
        if is_limit_up and limit_up_time is None:
            limit_up_time = tool.get_now_time_str()
        pricePre = gpcode_manager.CodePrePriceManager.get_price_pre_cache(code)
        if pricePre is None:
            history_k_data_manager.re_set_price_pres([code])
 
        rate = round((float(price) - pricePre) * 100 / pricePre, 1)
        prices.append(
            {"code": code, "time": limit_up_time, "rate": rate,
             "limit_up": is_limit_up})
 
    gpcode_first_screen_manager.process_ticks(prices)
    async_log_util.info(logger_l2_codes_subscript, f"({request_id})l2代码相关数据加载完成")
    return tick_datas