consolidator

Форк
0
77 строк · 4.8 Кб
1
import os
2
import sys
3
import pandas as pd
4
import datetime
5
from MainConsolidator import MainConsolidator
6

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

73
if __name__=="__roll__":
74
    consolidator:MainConsolidator
75
    record:pd.Series
76
    result:pd.Series
77
    result = handler.handle(record,consolidator)
78

79

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.