consolidator
54 строки · 2.9 Кб
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:
14try:
15diameter = consolidator.scalar_in_guid("Диаметры колес",f"`Производство`=='КПК Колесо' and `Диаметры SAP`=={row['Диаметр, мм <Производство>']}","Диаметры УП")
16weigth = consolidator.nearest_in_guid("Параметры по Продукту КПК",
17f"`Производство`=='КПК Колесо' and `Доп параметр1`=={diameter}",
18"Доп параметр2",
19row["Теоретический вес колеса, кг <Производство>"],
20"Доп параметр2")
21weigth_s=str(weigth).replace(".",",").replace(",0","")
22standart = consolidator.scalar_in_guid("Параметры по Продукту КПК",f"`Продукт`=='КОЛЕСО' and `Доп параметр1`=={diameter} and `Доп параметр2`=={weigth}","Доп параметр3")
23print(f"{row['Диаметр, мм <Производство>']} -> {diameter}: {row['Теоретический вес колеса, кг <Производство>']} -> {weigth_s} : {standart}")
24if pd.isna(diameter) or pd.isna(standart): raise Exception("Не определен вес или стандарт")
25row["error"] = pd.NA
26except Exception as exp:
27row["error"] = f"{exp}"
28finally:
29row["Продукт УП"]=f"КОЛЕСО Д{diameter} В{weigth_s} {standart}"
30row["Время укрупнения"]=datetime.datetime.now()
31return row
32
33def debug_handle(self,inputDf:pd.DataFrame,consolidator:MainConsolidator,module:str=None)->pd.DataFrame:
34try:
35if module is None: return inputDf.apply(lambda row: self.handle(row,consolidator), axis=1)
36else: return inputDf[inputDf["Производство2"]==module].apply(lambda row: self.handle(row,consolidator), axis=1)
37except: raise
38
39def get_compiled(self):
40code:str=f"print('{__file__}')"
41try:
42with open(__file__,encoding="utf-8",mode="r") as f:
43code=f.read()
44except Exception as exp:
45code=f"print('error: {exp}')"
46finally:
47cc = compile(code,"","exec")
48return cc
49
50if __name__=="__wheel__":
51consolidator:MainConsolidator
52record:pd.Series
53result:pd.Series
54result = handler.handle(record,consolidator)
55
56