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