consolidator
77 строк · 4.8 Кб
1import os
2import sys
3import pandas as pd
4import datetime
5from MainConsolidator import MainConsolidator
6
7class handler(object):
8@staticmethod
9def module_name():
10return 'ЛПК. Рулон'
11
12@staticmethod
13def handle(row:pd.Series,consolidator:MainConsolidator)->pd.Series:
14product_up=None
15try:
16row["Продукт УП"]=pd.NA
17steel_mark = row["Класс прочности <Производство>"] if pd.isna(row["Марка стали <Производство>"]) else row["Марка стали <Производство>"]
18cl_proch=consolidator.scalar_in_guid("Класс прочности по марке стали",f"`Марка стали`=='{steel_mark}'","Класс прочности")
19if not pd.isna(steel_mark) and pd.isna(cl_proch): cl_proch=steel_mark
20row["Марка стали <Производство>"]=steel_mark
21row["Класс прочности <Производство>"]=cl_proch
22steel_mark2=consolidator.scalar_in_guid("Маппинг класса прочности",f"`ИсX Класс прочности`=='{steel_mark}'", "Результ Класс прочности")
23cl_proch2=consolidator.scalar_in_guid("Маппинг класса прочности",f"`ИсX Класс прочности`=='{cl_proch}'", "Результ Класс прочности")
24if pd.notna(steel_mark2): row["Марка стали <Производство>"]=steel_mark2
25if pd.notna(cl_proch2): row["Марка стали <Производство>"]=cl_proch2
26if pd.isna(row["Марка стали <Производство>"]) : row["ГМСПС"]="ГУ"
27else : row["ГМСПС"]=pd.NA
28# # Уточнение ГМСПС
29gmsps=consolidator.scalar_in_guid("Группы марок стали по потребительским свойствам", f"`Марка стали`=='{row['Марка стали <Производство>']}'", "Группа марок")
30if pd.notna(gmsps): row["ГМСПС"]=gmsps
31oto = consolidator.scalar_in_guid("Признак по НТД",
32f"`Производство`=='{row['Производство2']}' and `НТД качества (трубы стальные) <Производство>`=='{row['НТД качества (прокат) <Производство>']}'",
33"Доп параметр1")
34if pd.notna(oto): row["ГМСПС"]=oto
35# row[['Толщина, мм <Производство>']].fillna("")
36w=row['Толщина, мм <Производство>']
37# print(f"w={w} ({row['Толщина, мм <Производство>']}) : {pd.isna(row['Толщина, мм <Производство>'])}")
38thickness_range = consolidator.scalar_in_guid("Параметры по Продукту Прокат",
39f"`Производство`=='Рулон' and `Продукт`=='РУЛОН' and `Мин`<={w}<=`Макс` and `Доп параметр1` == '{row['ГМСПС']}'",
40"Диапазон")
41
42product_up="РУЛОН "+row["ГМСПС"]
43if pd.notna(row["ГМСПС"]) and "ГУ" in str(row["ГМСПС"]) and pd.notna(thickness_range) :
44product_up = f"РУЛОН {thickness_range} ГУ"
45if str(row["Признак БЗ"])=="БЗ":
46product_up = "РУЛОН Р БЗ"
47row["error"] = pd.NA
48except Exception as exp:
49row["error"] = f"{exp}"
50finally:
51row["Продукт УП"]=product_up
52row["Время укрупнения"]=datetime.datetime.now()
53return row
54
55# @staticmethod
56def debug_handle(self,inputDf:pd.DataFrame,consolidator:MainConsolidator,module:str=None)->pd.DataFrame:
57try:
58if module is None: return inputDf.apply(lambda row: self.handle(row,consolidator), axis=1)
59else: return inputDf[inputDf["Производство2"]==module].apply(lambda row: self.handle(row,consolidator), axis=1)
60except: raise
61
62def get_compiled(self):
63code:str=f"print('{__file__}')"
64try:
65with open(__file__,encoding="utf-8",mode="r") as f:
66code=f.read()
67except Exception as exp:
68code=f"print('error: {exp}')"
69finally:
70cc = compile(code,"","exec")
71return cc
72
73if __name__=="__roll__":
74consolidator:MainConsolidator
75record:pd.Series
76result:pd.Series
77result = handler.handle(record,consolidator)
78
79