123456789101112131415161718192021222324252627282930313233343536 |
- import pandas as pd
- import datacompy
- class DiagDataMerge():
- def DetaMerge(df_Diag_Ram_sn,df_Diag_Batdiag_update,df_OprtnSta,df_Diag_Ram_sn_else):
- df_Diag_Ram_add = pd.DataFrame()
- df_Diag_Ram_Update_change = pd.DataFrame()
-
- df_Diag_Cal_finish = pd.DataFrame(columns=['start_time', 'end_time', 'product_id', 'code', 'level', 'info','advice','Batpos'])
- df_Diag_Cal_unfinish = pd.DataFrame(columns=['start_time', 'end_time', 'product_id', 'code', 'level', 'info','advice','Batpos'])
- print('处理前',df_Diag_Cal_unfinish)
- if not df_Diag_Batdiag_update.empty:
- #------------------------------合并两者故障,并将同一sn号下的车辆故障放一起----------------------------------------------
- df_Diag_Cal_finish = df_Diag_Batdiag_update[df_Diag_Batdiag_update['end_time'] != '0000-00-00 00:00:00']
- df_Diag_Cal_unfinish = df_Diag_Batdiag_update[df_Diag_Batdiag_update['end_time'] == '0000-00-00 00:00:00']
- df_Diag_Cal_finish['Batpos'] = [1]*len(df_Diag_Cal_finish)
- if len(df_OprtnSta):
- if df_OprtnSta.loc[0,'status'] !=1:#0禁用 1正常 2故障 3返修 4 损毁 5丢失已赔偿,6丢失未赔偿
- if df_Diag_Cal_unfinish['level'].max()>3:
- if df_OprtnSta.loc[0,'status'] ==3:
- df_Diag_Cal_unfinish['Batpos'] = [1]*len(df_Diag_Cal_unfinish)
- else:
- df_Diag_Cal_unfinish['Batpos'] = [0]*len(df_Diag_Cal_unfinish)
- else:
- df_Diag_Cal_unfinish['Batpos'] = [1]*len(df_Diag_Cal_unfinish)
- else:
- df_Diag_Cal_unfinish['Batpos'] = [0]*len(df_Diag_Cal_unfinish)
-
- print('处理后',df_Diag_Cal_unfinish)
- df_Diag_Cal_Update=pd.concat([df_Diag_Cal_finish,df_Diag_Cal_unfinish])
- df_Diag_Ram_add = pd.concat([df_Diag_Cal_Update,df_Diag_Ram_sn,df_Diag_Ram_sn]).drop_duplicates(subset=['start_time','code'],keep=False)#此次判断中新增故障
- df_Diag_Ram_Update_old = pd.concat([df_Diag_Cal_Update,df_Diag_Ram_add,df_Diag_Ram_add]).drop_duplicates(subset=['start_time','code'],keep=False)#此次判断中新增故障
- df_Diag_Ram_Update_change = pd.concat([df_Diag_Ram_Update_old,df_Diag_Ram_sn,df_Diag_Ram_sn]).drop_duplicates(subset=['start_time','code','Batpos'],keep=False)#此次判断中新增故障
- # df_Diag_Ram = pd.concat([df_Diag_Ram_sn_else,df_Diag_Cal_unfinish])
- return df_Diag_Ram_add,df_Diag_Ram_Update_change
|