diff --git a/func/Module_SA_label.py b/func/Module_SA_label.py
index acc017f..365ade7 100644
--- a/func/Module_SA_label.py
+++ b/func/Module_SA_label.py
@@ -362,6 +362,7 @@ class MainWindow_SA_label(QMainWindow):
self.ui.pushButton_prev.clicked.connect(self.__slot_btn_move__)
self.ui.pushButton_next.clicked.connect(self.__slot_btn_move__)
self.ui.pushButton_confirmLabel.clicked.connect(self.__slot_btn_confirmLabel__)
+ self.ui.pushButton_save.clicked.connect(self.__slot_btn_save__)
self.ui.pushButton_quick_remark_input_waitingForTalk.clicked.connect(self.__slot_btn_quick_remark__)
self.ui.pushButton_quick_remark_input_maybeDesaturation.clicked.connect(self.__slot_btn_quick_remark__)
self.ui.pushButton_quick_remark_input_maybeWrongLabeled.clicked.connect(self.__slot_btn_quick_remark__)
@@ -633,83 +634,105 @@ class MainWindow_SA_label(QMainWindow):
self.data = Data()
# 导入数据
- PublicFunc.progressbar_update(self, 1, 7, Constants.INPUTTING_DATA, 0)
+ PublicFunc.progressbar_update(self, 1, 9, Constants.INPUTTING_DATA, 0)
result = self.data.open_file()
if not result.status:
- PublicFunc.text_output(self.ui, "(1/7)" + result.info, Constants.TIPS_TYPE_ERROR)
+ PublicFunc.text_output(self.ui, "(1/9)" + result.info, Constants.TIPS_TYPE_ERROR)
PublicFunc.msgbox_output(self, result.info, Constants.MSGBOX_TYPE_ERROR)
PublicFunc.finish_operation(self, ButtonState)
return
else:
- PublicFunc.text_output(self.ui, "(1/7)" + result.info, Constants.TIPS_TYPE_INFO)
+ PublicFunc.text_output(self.ui, "(1/9)" + result.info, Constants.TIPS_TYPE_INFO)
# 获取存档
- PublicFunc.progressbar_update(self, 2, 7, Constants.LOADING_ARCHIVE, 20)
+ PublicFunc.progressbar_update(self, 2, 9, Constants.LOADING_ARCHIVE, 15)
result = self.data.get_archive()
if not result.status:
- PublicFunc.text_output(self.ui, "(2/7)" + result.info, Constants.TIPS_TYPE_ERROR)
+ PublicFunc.text_output(self.ui, "(2/9)" + result.info, Constants.TIPS_TYPE_ERROR)
PublicFunc.msgbox_output(self, result.info, Constants.MSGBOX_TYPE_ERROR)
PublicFunc.finish_operation(self, ButtonState)
return
else:
- PublicFunc.text_output(self.ui, "(2/7)" + result.info, Constants.TIPS_TYPE_INFO)
+ PublicFunc.text_output(self.ui, "(2/9)" + result.info, Constants.TIPS_TYPE_INFO)
+
+ # 保存
+ PublicFunc.progressbar_update(self, 3, 9, Constants.SAVING_DATA, 20)
+ result = self.data.save()
+ if not result.status:
+ PublicFunc.text_output(self.ui, "(3/9)" + result.info, Constants.TIPS_TYPE_ERROR)
+ PublicFunc.msgbox_output(self, result.info, Constants.MSGBOX_TYPE_ERROR)
+ PublicFunc.finish_operation(self, ButtonState)
+ return
+ else:
+ PublicFunc.text_output(self.ui, "(3/9)" + result.info, Constants.TIPS_TYPE_INFO)
+
+ # 保存
+ PublicFunc.progressbar_update(self, 4, 9, Constants.SAVING_DATA, 25)
+ result = self.data.save_2()
+ if not result.status:
+ PublicFunc.text_output(self.ui, "(4/9)" + result.info, Constants.TIPS_TYPE_ERROR)
+ PublicFunc.msgbox_output(self, result.info, Constants.MSGBOX_TYPE_ERROR)
+ PublicFunc.finish_operation(self, ButtonState)
+ return
+ else:
+ PublicFunc.text_output(self.ui, "(4/9)" + result.info, Constants.TIPS_TYPE_INFO)
# 数据预处理
- PublicFunc.progressbar_update(self, 3, 7, Constants.PREPROCESSING_DATA, 30)
+ PublicFunc.progressbar_update(self, 5, 9, Constants.PREPROCESSING_DATA, 30)
result = self.data.preprocess()
if not result.status:
- PublicFunc.text_output(self.ui, "(3/7)" + result.info, Constants.TIPS_TYPE_ERROR)
+ PublicFunc.text_output(self.ui, "(5/9)" + result.info, Constants.TIPS_TYPE_ERROR)
PublicFunc.msgbox_output(self, result.info, Constants.MSGBOX_TYPE_ERROR)
PublicFunc.finish_operation(self, ButtonState)
return
else:
- PublicFunc.text_output(self.ui, "(3/7)" + result.info, Constants.TIPS_TYPE_INFO)
+ PublicFunc.text_output(self.ui, "(5/9)" + result.info, Constants.TIPS_TYPE_INFO)
# 重采样
- PublicFunc.progressbar_update(self, 4, 7, Constants.RESAMPLING_DATA, 50)
+ PublicFunc.progressbar_update(self, 6, 9, Constants.RESAMPLING_DATA, 50)
result = self.data.resample()
for key, value in self.data.channel.items():
PublicFunc.text_output(self.ui, key + "重采样后的长度:" + str(len(value)), Constants.TIPS_TYPE_INFO)
if not result.status:
- PublicFunc.text_output(self.ui, "(4/7)" + result.info, Constants.TIPS_TYPE_ERROR)
+ PublicFunc.text_output(self.ui, "(6/9)" + result.info, Constants.TIPS_TYPE_ERROR)
PublicFunc.msgbox_output(self, result.info, Constants.MSGBOX_TYPE_ERROR)
PublicFunc.finish_operation(self, ButtonState)
return
else:
- PublicFunc.text_output(self.ui, "(4/7)" + result.info, Constants.TIPS_TYPE_INFO)
+ PublicFunc.text_output(self.ui, "(6/9)" + result.info, Constants.TIPS_TYPE_INFO)
# 绘图
- PublicFunc.progressbar_update(self, 5, 7, Constants.DRAWING_DATA, 70)
+ PublicFunc.progressbar_update(self, 7, 9, Constants.DRAWING_DATA, 70)
result = self.__plot__()
if not result.status:
- PublicFunc.text_output(self.ui, "(5/7)" + result.info, Constants.TIPS_TYPE_ERROR)
+ PublicFunc.text_output(self.ui, "(7/9)" + result.info, Constants.TIPS_TYPE_ERROR)
PublicFunc.msgbox_output(self, result.info, Constants.MSGBOX_TYPE_ERROR)
PublicFunc.finish_operation(self, ButtonState)
return
else:
- PublicFunc.text_output(self.ui, "(5/7)" + result.info, Constants.TIPS_TYPE_INFO)
+ PublicFunc.text_output(self.ui, "(7/9)" + result.info, Constants.TIPS_TYPE_INFO)
# 更新表格
- PublicFunc.progressbar_update(self, 6, 7, Constants.UPDATING_TABLEWIDGET, 90)
+ PublicFunc.progressbar_update(self, 8, 9, Constants.UPDATING_TABLEWIDGET, 90)
result = self.update_tableWidget()
if not result.status:
- PublicFunc.text_output(self.ui, "(6/7)" + result.info, Constants.TIPS_TYPE_ERROR)
+ PublicFunc.text_output(self.ui, "(8/9)" + result.info, Constants.TIPS_TYPE_ERROR)
PublicFunc.msgbox_output(self, result.info, Constants.MSGBOX_TYPE_ERROR)
PublicFunc.finish_operation(self, ButtonState)
return
else:
- PublicFunc.text_output(self.ui, "(6/7)" + result.info, Constants.TIPS_TYPE_INFO)
+ PublicFunc.text_output(self.ui, "(8/9)" + result.info, Constants.TIPS_TYPE_INFO)
# 更新信息
- PublicFunc.progressbar_update(self, 7, 7, Constants.UPDATING_INFO, 95)
+ PublicFunc.progressbar_update(self, 9, 9, Constants.UPDATING_INFO, 95)
result = self.update_UI_Args()
if not result.status:
- PublicFunc.text_output(self.ui, "(7/7)" + result.info, Constants.TIPS_TYPE_ERROR)
+ PublicFunc.text_output(self.ui, "(9/9)" + result.info, Constants.TIPS_TYPE_ERROR)
PublicFunc.msgbox_output(self, result.info, Constants.MSGBOX_TYPE_ERROR)
PublicFunc.finish_operation(self, ButtonState)
return
else:
- PublicFunc.text_output(self.ui, "(7/7)" + result.info, Constants.TIPS_TYPE_INFO)
+ PublicFunc.text_output(self.ui, "(9/9)" + result.info, Constants.TIPS_TYPE_INFO)
if (self.data.df_corrected["isLabeled"] == 1).all():
self.ui.checkBox_examineLabeled.setChecked(False)
@@ -779,8 +802,13 @@ class MainWindow_SA_label(QMainWindow):
self.data.df_addNew = self.pd_add_new_row(self.data.df_addNew, score, remark, correct_Start,
correct_End, correct_EventsType, isLabeled)
result = self.data.save_2()
- info = f"保存新事件打标结果到csv。score:{str(score)},correct_Start:{str(correct_Start)},correct_End:{str(correct_End)},correct_EventsType:{str(correct_EventsType)}"
- PublicFunc.text_output(self.ui, info, Constants.MSGBOX_TYPE_INFO)
+ if result.status:
+ info = f"保存新事件打标结果到csv。score:{str(score)},correct_Start:{str(correct_Start)},correct_End:{str(correct_End)},correct_EventsType:{str(correct_EventsType)}"
+ PublicFunc.text_output(self.ui, info, Constants.TIPS_TYPE_INFO)
+ else:
+ info = f"未成功保存新事件打标结果到csv,错误提示:{result.info},结果已暂存到缓存中,请正确操作后重试。score:{str(score)},correct_Start:{str(correct_Start)},correct_End:{str(correct_End)},correct_EventsType:{str(correct_EventsType)}"
+ PublicFunc.text_output(self.ui, info, Constants.TIPS_TYPE_ERROR)
+ PublicFunc.msgbox_output(self, info, Constants.MSGBOX_TYPE_ERROR)
else:
PublicFunc.msgbox_output(self, Constants.SA_LABEL_WRONG_ARGS, Constants.MSGBOX_TYPE_ERROR)
else:
@@ -810,17 +838,19 @@ class MainWindow_SA_label(QMainWindow):
self.data.df_corrected.at[Config["EventLabelIndexList"][
Config["PlotEventIndex"]], "correct_EventsType"] = "Hypopnea"
self.data.df_corrected.at[Config["EventLabelIndexList"][Config["PlotEventIndex"]], "isLabeled"] = int(1)
- # self.data.df_corrected.to_csv(
- # self.BCG_Label_Path / f"export{self.mainWindow.ui_SA_label_left.comboBox_sampID.currentText()}_all.csv",
- # mode='w', index=None, encoding="gbk")
result = self.data.save()
index = str(Config["PlotEventIndex"] + 1)
score = str(self.data.df_corrected.at[Config["EventLabelIndexList"][Config["PlotEventIndex"]], "score"])
correct_Start = str(self.data.df_corrected.at[Config["EventLabelIndexList"][Config["PlotEventIndex"]], "correct_Start"])
correct_End = str(self.data.df_corrected.at[Config["EventLabelIndexList"][Config["PlotEventIndex"]], "correct_End"])
correct_EventsType = str(self.data.df_corrected.at[Config["EventLabelIndexList"][Config["PlotEventIndex"]], "correct_EventsType"])
- info = f"保存index{index}标注结果到csv。score:{score},correct_Start:{correct_Start},correct_End:{correct_End},correct_EventsType:{correct_EventsType}"
- PublicFunc.text_output(self.ui, info, Constants.MSGBOX_TYPE_INFO)
+ if result.status:
+ info = f"保存index{index}标注结果到csv。score:{score},correct_Start:{correct_Start},correct_End:{correct_End},correct_EventsType:{correct_EventsType}"
+ PublicFunc.text_output(self.ui, info, Constants.TIPS_TYPE_INFO)
+ else:
+ info = f"未成功保存index{index}标注结果到csv,错误提示:{result.info},结果已暂存到缓存中,请正确操作后重试。score:{score},correct_Start:{correct_Start},correct_End:{correct_End},correct_EventsType:{correct_EventsType}"
+ PublicFunc.text_output(self.ui, info, Constants.TIPS_TYPE_ERROR)
+ PublicFunc.msgbox_output(self, info, Constants.MSGBOX_TYPE_ERROR)
if (self.data.df_corrected.loc[Config["EventLabelIndexList"]]["isLabeled"] == 1).all():
self.ui.checkBox_examineLabeled.setChecked(False)
PublicFunc.text_output(self.ui, Constants.SA_LABEL_ALL_LABELED, Constants.TIPS_TYPE_INFO)
@@ -832,6 +862,34 @@ class MainWindow_SA_label(QMainWindow):
info = Constants.SAVE_FAILURE + "\n" + format_exc()
PublicFunc.msgbox_output(self, info, Constants.MSGBOX_TYPE_ERROR)
+ def __slot_btn_save__(self):
+ PublicFunc.__disableAllButton__(self, ButtonState)
+
+ # 保存
+ PublicFunc.progressbar_update(self, 1, 2, Constants.SAVING_DATA, 0)
+ result = self.data.save()
+ if not result.status:
+ PublicFunc.text_output(self.ui, "(1/2)" + result.info, Constants.TIPS_TYPE_ERROR)
+ PublicFunc.msgbox_output(self, result.info, Constants.MSGBOX_TYPE_ERROR)
+ PublicFunc.finish_operation(self, ButtonState)
+ return
+ else:
+ PublicFunc.text_output(self.ui, "(1/2)" + result.info, Constants.TIPS_TYPE_INFO)
+
+ # 保存
+ PublicFunc.progressbar_update(self, 2, 2, Constants.SAVING_DATA, 50)
+ result = self.data.save_2()
+ if not result.status:
+ PublicFunc.text_output(self.ui, "(2/2)" + result.info, Constants.TIPS_TYPE_ERROR)
+ PublicFunc.msgbox_output(self, result.info, Constants.MSGBOX_TYPE_ERROR)
+ PublicFunc.finish_operation(self, ButtonState)
+ return
+ else:
+ PublicFunc.text_output(self.ui, "(2/2)" + result.info, Constants.TIPS_TYPE_INFO)
+
+ PublicFunc.msgbox_output(self, result.info, Constants.TIPS_TYPE_INFO)
+ PublicFunc.finish_operation(self, ButtonState)
+
def __slot_btn_move__(self):
if self.data is None:
return
@@ -1595,6 +1653,10 @@ class Data:
try:
self.df_corrected.to_csv(Config["Path"]["Save"], mode='w', index=None, encoding="gbk")
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.SAVE_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
@@ -1610,6 +1672,10 @@ class Data:
try:
self.df_addNew.to_csv(Config["Path"]["Save_2"], mode='w', index=None, encoding="gbk")
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.SAVE_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
diff --git a/func/Module_approximately_align.py b/func/Module_approximately_align.py
index d013997..6fec23b 100644
--- a/func/Module_approximately_align.py
+++ b/func/Module_approximately_align.py
@@ -1046,6 +1046,10 @@ class Data:
})
df.to_csv(Path(Config["Path"]["Save"]), mode="w", header=True, index=False)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON[
"Save_Exception"] + "\n" + format_exc())
@@ -1307,7 +1311,6 @@ class Data:
tho_bias_list.append(tho_seg_pos / temp_freq)
abd_bias_list.append(abd_seg_pos / temp_freq)
-
result = {
"tho_bias_list": tho_bias_list,
"abd_bias_list": abd_bias_list,
@@ -1315,7 +1318,6 @@ class Data:
"epoch_max": epoch_max
}
-
except Exception as e:
return Result().failure(
info=Constants.APPROXIMATELY_EPOCH_GET_FAILURE + Constants.FAILURE_REASON[
diff --git a/func/Module_artifact_label.py b/func/Module_artifact_label.py
index 4c946ae..9063d79 100644
--- a/func/Module_artifact_label.py
+++ b/func/Module_artifact_label.py
@@ -1338,7 +1338,7 @@ class Data:
def resample(self):
if self.orgBcg is None:
- Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
+ return Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
try:
if Config["InputConfig"]["orgBcgFreq"] != Config["InputConfig"]["UseFreq"]:
@@ -1348,8 +1348,8 @@ class Data:
else:
return Result().success(info=Constants.RESAMPLE_NO_NEED)
except Exception as e:
- Result().failure(info=Constants.RESAMPLE_FAILURE +
- Constants.FAILURE_REASON["Resample_Exception"] + "\n" + format_exc())
+ return Result().failure(info=Constants.RESAMPLE_FAILURE +
+ Constants.FAILURE_REASON["Resample_Exception"] + "\n" + format_exc())
return Result().success(info=Constants.RESAMPLE_FINISHED)
@@ -1399,6 +1399,10 @@ class Data:
df_Artifact_b.to_csv(Path(Config["Path"]["Save_b"]), header=False, index=False, sep='\n')
self.df_Artifact_a.to_csv(Path(Config["Path"]["Save_c"]), index=False,
encoding=Params.GBK_ENCODING)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON[
"Save_Exception"] + "\n" + format_exc())
diff --git a/func/Module_bcg_quality_label.py b/func/Module_bcg_quality_label.py
index d903e9f..d48fe7d 100644
--- a/func/Module_bcg_quality_label.py
+++ b/func/Module_bcg_quality_label.py
@@ -1072,7 +1072,7 @@ class Data():
def resample(self):
if self.BCG is None:
- Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
+ return Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
try:
if Config["InputConfig"]["BCGFreq"] != Config["InputConfig"]["UseFreq"]:
@@ -1082,8 +1082,8 @@ class Data():
else:
return Result().success(info=Constants.RESAMPLE_NO_NEED)
except Exception as e:
- Result().failure(info=Constants.RESAMPLE_FAILURE +
- Constants.FAILURE_REASON["Resample_Exception"] + "\n" + format_exc())
+ return Result().failure(info=Constants.RESAMPLE_FAILURE +
+ Constants.FAILURE_REASON["Resample_Exception"] + "\n" + format_exc())
return Result().success(info=Constants.RESAMPLE_FINISHED)
@@ -1112,6 +1112,10 @@ class Data():
try:
self.df_label.to_csv(Config["Path"]["Save"], index=False, encoding=Params.GBK_ENCODING)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=filename + Constants.SAVE_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
diff --git a/func/Module_cut_PSG.py b/func/Module_cut_PSG.py
index 1d43c64..6b2ff69 100644
--- a/func/Module_cut_PSG.py
+++ b/func/Module_cut_PSG.py
@@ -335,6 +335,10 @@ class Data:
self.SALabel.to_csv(Path(Config["Path"]["SaveFolder"]) / Path((Config["LabelSave"]["SA Label"] + Config["EndWith"]["SA Label"])),
index=False,
encoding="gbk")
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.SAVE_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
diff --git a/func/Module_detect_Jpeak.py b/func/Module_detect_Jpeak.py
index 11f36ff..0cf45e7 100644
--- a/func/Module_detect_Jpeak.py
+++ b/func/Module_detect_Jpeak.py
@@ -424,6 +424,10 @@ class Data:
Constants.FAILURE_REASON["Data_Not_Exist"])
try:
+ if ((Config["Filter"]["BandPassLow"] >= Config["Filter"]["BandPassHigh"]) or
+ (Config["Filter"]["BandPassLow"] <= 0) or (Config["Filter"]["BandPassHigh"] <= 0)):
+ return Result().failure(
+ info=Constants.PREPROCESS_FAILURE + Constants.FAILURE_REASON["Filter_Args_Not_Correct"])
self.processed_data = preprocess(self.raw_data,
Config["InputConfig"]["Freq"],
Config["Filter"]["BandPassLow"],
@@ -445,6 +449,9 @@ class Data:
Constants.FAILURE_REASON["Data_Not_Exist"])
try:
+ if Config["IntervalLow"] >= Config["IntervalHigh"]:
+ return Result().failure(
+ info=Constants.DETECT_JPEAK_PREDICT_FAILURE + Constants.FAILURE_REASON["Interval_Args_Not_Correct"])
self.peak, self.interval = Jpeak_Detection(model.selected_model,
Path(model.model_folder_path) / Path(model.selected_model),
self.processed_data,
@@ -465,6 +472,10 @@ class Data:
try:
chunk.to_csv(Config["Path"]["Save"], mode='a', index=False, header=False)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.SAVE_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
diff --git a/func/Module_detect_Rpeak.py b/func/Module_detect_Rpeak.py
index f884eb4..06c56d6 100644
--- a/func/Module_detect_Rpeak.py
+++ b/func/Module_detect_Rpeak.py
@@ -425,6 +425,10 @@ class Data:
Constants.FAILURE_REASON["Data_Not_Exist"])
try:
+ if ((Config["Filter"]["BandPassLow"] >= Config["Filter"]["BandPassHigh"]) or
+ (Config["Filter"]["BandPassLow"] <= 0) or (Config["Filter"]["BandPassHigh"] <= 0)):
+ return Result().failure(
+ info=Constants.PREPROCESS_FAILURE + Constants.FAILURE_REASON["Filter_Args_Not_Correct"])
self.processed_data = preprocess(self.raw_data,
Config["InputConfig"]["Freq"],
Config["Filter"]["BandPassLow"],
@@ -458,6 +462,10 @@ class Data:
try:
chunk.to_csv(Config["Path"]["Save"], mode='a', index=False, header=False)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.SAVE_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
diff --git a/func/Module_label_check.py b/func/Module_label_check.py
index e28b0b1..8711f0d 100644
--- a/func/Module_label_check.py
+++ b/func/Module_label_check.py
@@ -986,17 +986,31 @@ class Data:
try:
if Config["Mode"] == "BCG":
- self.processed_data = data_preprocess_for_label_check(self.raw_data,
- Config["Filter"]["BCGBandPassOrder"],
- Config["Filter"]["BCGBandPassLow"],
- Config["Filter"]["BCGBandPassHigh"],
- Config["InputConfig"]["Freq"])
+ if Config["Filter"]["BCGBandPassOrder"] == 0:
+ self.processed_data = self.raw_data
+ else:
+ if ((Config["Filter"]["BCGBandPassLow"] >= Config["Filter"]["BCGBandPassHigh"]) or
+ (Config["Filter"]["BCGBandPassLow"] <= 0) or (Config["Filter"]["BCGBandPassHigh"] <= 0)):
+ return Result().failure(
+ info=Constants.PREPROCESS_FAILURE + Constants.FAILURE_REASON["Filter_Args_Not_Correct"])
+ self.processed_data = data_preprocess_for_label_check(self.raw_data,
+ Config["Filter"]["BCGBandPassOrder"],
+ Config["Filter"]["BCGBandPassLow"],
+ Config["Filter"]["BCGBandPassHigh"],
+ Config["InputConfig"]["Freq"])
elif Config["Mode"] == "ECG":
- self.processed_data = data_preprocess_for_label_check(self.raw_data,
- Config["Filter"]["ECGBandPassOrder"],
- Config["Filter"]["ECGBandPassLow"],
- Config["Filter"]["ECGBandPassHigh"],
- Config["InputConfig"]["Freq"])
+ if Config["Filter"]["ECGBandPassOrder"] == 0:
+ self.processed_data = self.raw_data
+ else:
+ if ((Config["Filter"]["ECGBandPassLow"] >= Config["Filter"]["ECGBandPassHigh"]) or
+ (Config["Filter"]["ECGBandPassLow"] <= 0) or (Config["Filter"]["ECGBandPassHigh"] <= 0)):
+ return Result().failure(
+ info=Constants.PREPROCESS_FAILURE + Constants.FAILURE_REASON["Filter_Args_Not_Correct"])
+ self.processed_data = data_preprocess_for_label_check(self.raw_data,
+ Config["Filter"]["ECGBandPassOrder"],
+ Config["Filter"]["ECGBandPassLow"],
+ Config["Filter"]["ECGBandPassHigh"],
+ Config["InputConfig"]["Freq"])
else:
raise ValueError("模式不存在")
self.original_peak_y = [self.processed_data[x] for x in self.original_peak]
@@ -1013,6 +1027,10 @@ class Data:
try:
DataFrame(self.corrected_peak).to_csv(Config["Path"]["Save"], index=False, header=False)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.SAVE_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
diff --git a/func/Module_mainwindow.py b/func/Module_mainwindow.py
index 214dad5..9fb1591 100644
--- a/func/Module_mainwindow.py
+++ b/func/Module_mainwindow.py
@@ -277,6 +277,7 @@ class MainWindow(QMainWindow, Ui_Signal_Label):
def seek_sampID(self, path):
if not Path(path).exists():
PublicFunc.msgbox_output(self, Constants.MAINWINDOW_ROOT_PATH_NOT_EXIST, Constants.MSGBOX_TYPE_ERROR)
+ self.ui.comboBox_sampID.clear()
return
sub_folders = [item.name for item in Path(path).iterdir() if item.is_dir()]
diff --git a/func/Module_precisely_align.py b/func/Module_precisely_align.py
index 81dcdd7..cb10bb9 100644
--- a/func/Module_precisely_align.py
+++ b/func/Module_precisely_align.py
@@ -1679,7 +1679,7 @@ class Data:
def resample(self):
if self.raw_orgBcg is None or self.raw_BCG is None or self.raw_ECG is None:
- Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
+ return Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
try:
if Config["InputConfig"]["orgBcgFreq"] != Config["InputConfig"]["UseFreq"]:
@@ -1690,8 +1690,8 @@ class Data:
else:
return Result().success(info=Constants.RESAMPLE_NO_NEED)
except Exception as e:
- Result().failure(info=Constants.RESAMPLE_FAILURE +
- Constants.FAILURE_REASON["Resample_Exception"] + "\n" + format_exc())
+ return Result().failure(info=Constants.RESAMPLE_FAILURE +
+ Constants.FAILURE_REASON["Resample_Exception"] + "\n" + format_exc())
return Result().success(info=Constants.RESAMPLE_FINISHED)
@@ -2033,6 +2033,10 @@ class Data:
}
save_data = [str(save_data)]
DataFrame(save_data).to_csv(Config["Path"]["Save_AlignInfo"], index=False, header=False)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.PRECISELY_ALIGN_SAVING_ALIGNINFO_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
@@ -2055,6 +2059,10 @@ class Data:
try:
chunk.to_csv(Config["Path"]["Save_OrgBCG"], mode='a', index=False, header=False)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.PRECISELY_ALIGN_SAVING_RES_ORGBCG_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
@@ -2072,6 +2080,10 @@ class Data:
try:
chunk.to_csv(Config["Path"]["Save_BCG"], mode='a', index=False, header=False)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.PRECISELY_ALIGN_SAVING_RES_BCG_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
@@ -2089,6 +2101,10 @@ class Data:
try:
chunk.to_csv(Config["Path"]["Save_ECG"], mode='a', index=False, header=False)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.PRECISELY_ALIGN_SAVING_CUT_ECG_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
@@ -2106,6 +2122,10 @@ class Data:
try:
chunk.to_csv(Config["Path"]["Save_Jpeak"], mode='a', index=False, header=False)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.PRECISELY_ALIGN_SAVING_CUT_JPEAK_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
@@ -2123,6 +2143,10 @@ class Data:
try:
chunk.to_csv(Config["Path"]["Save_Rpeak"], mode='a', index=False, header=False)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.PRECISELY_ALIGN_SAVING_CUT_RPEAK_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
diff --git a/func/Module_preprocess.py b/func/Module_preprocess.py
index f016e26..36e8e80 100644
--- a/func/Module_preprocess.py
+++ b/func/Module_preprocess.py
@@ -432,7 +432,7 @@ class Data:
def resample(self):
if self.raw_data is None:
- Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
+ return Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
try:
if Config["InputConfig"]["Freq"] != Config["OutputConfig"]["Freq"]:
@@ -442,34 +442,47 @@ class Data:
else:
return Result().success(info=Constants.RESAMPLE_NO_NEED)
except Exception as e:
- Result().failure(info=Constants.RESAMPLE_FAILURE +
+ return Result().failure(info=Constants.RESAMPLE_FAILURE +
Constants.FAILURE_REASON["Resample_Exception"] + "\n" + format_exc())
return Result().success(info=Constants.RESAMPLE_FINISHED)
def preprocess(self):
if self.raw_data is None:
- Result().failure(info=Constants.PREPROCESS_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
+ return Result().failure(info=Constants.PREPROCESS_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
try:
-
if Config["Mode"] == "BCG":
- self.processed_data = Butterworth_for_BCG_PreProcess(self.raw_data, type='bandpass',
- low_cut=Config["Filter"]["BCGBandPassLow"],
- high_cut=Config["Filter"]["BCGBandPassHigh"],
- order=Config["Filter"]["BCGBandPassOrder"],
- sample_rate=Config["OutputConfig"]["Freq"])
+ if Config["Filter"]["BCGBandPassOrder"] == 0:
+ self.processed_data = self.raw_data
+ else:
+ if ((Config["Filter"]["BCGBandPassLow"] >= Config["Filter"]["BCGBandPassHigh"]) or
+ (Config["Filter"]["BCGBandPassLow"] <= 0) or (Config["Filter"]["BCGBandPassHigh"] <= 0)):
+ return Result().failure(
+ info=Constants.PREPROCESS_FAILURE + Constants.FAILURE_REASON["Filter_Args_Not_Correct"])
+ self.processed_data = Butterworth_for_BCG_PreProcess(self.raw_data, type='bandpass',
+ low_cut=Config["Filter"]["BCGBandPassLow"],
+ high_cut=Config["Filter"]["BCGBandPassHigh"],
+ order=Config["Filter"]["BCGBandPassOrder"],
+ sample_rate=Config["OutputConfig"]["Freq"])
elif Config["Mode"] == "ECG":
- self.processed_data = Butterworth_for_ECG_PreProcess(self.raw_data, type='bandpass',
- low_cut=Config["Filter"]["ECGBandPassLow"],
- high_cut=Config["Filter"]["ECGBandPassHigh"],
- order=Config["Filter"]["ECGBandPassOrder"],
- sample_rate=Config["OutputConfig"]["Freq"])
+ if Config["Filter"]["ECGBandPassOrder"] == 0:
+ self.processed_data = self.raw_data
+ else:
+ if ((Config["Filter"]["ECGBandPassLow"] >= Config["Filter"]["ECGBandPassHigh"]) or
+ (Config["Filter"]["ECGBandPassLow"] <= 0) or (Config["Filter"]["ECGBandPassHigh"] <= 0)):
+ return Result().failure(
+ info=Constants.PREPROCESS_FAILURE + Constants.FAILURE_REASON["Filter_Args_Not_Correct"])
+ self.processed_data = Butterworth_for_ECG_PreProcess(self.raw_data, type='bandpass',
+ low_cut=Config["Filter"]["ECGBandPassLow"],
+ high_cut=Config["Filter"]["ECGBandPassHigh"],
+ order=Config["Filter"]["ECGBandPassOrder"],
+ sample_rate=Config["OutputConfig"]["Freq"])
else:
raise ValueError("模式不存在")
except Exception as e:
- Result().failure(info=Constants.PREPROCESS_FAILURE +
- Constants.FAILURE_REASON["Preprocess_Exception"] + "\n" + format_exc())
+ return Result().failure(info=Constants.PREPROCESS_FAILURE +
+ Constants.FAILURE_REASON["Preprocess_Exception"] + "\n" + format_exc())
return Result().success(info=Constants.PREPROCESS_FINISHED)
@@ -479,6 +492,10 @@ class Data:
try:
chunk.to_csv(Config["Path"]["Save"], mode='a', index=False, header=False, float_format='%.4f')
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Constants.SAVE_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
diff --git a/func/Module_resp_quality_label.py b/func/Module_resp_quality_label.py
index 5da029e..cf0981a 100644
--- a/func/Module_resp_quality_label.py
+++ b/func/Module_resp_quality_label.py
@@ -411,7 +411,7 @@ class MainWindow_resp_quality_label(QMainWindow):
artifact_type_seq = append(artifact_type_seq, 4)
if self.ui.checkBox_type5.isChecked():
artifact_type_seq = append(artifact_type_seq, 5)
- length = Config["InputConfig"]["OrgBCGUseFreq"] * Params.RESP_QUALITY_LABEL_PARTS_TIME_SEC
+ length = end_OrgBCG - begin_OrgBCG
mask = array([arange(length), arange(length), arange(length), arange(length), arange(length), arange(length)])
mask = mask.astype(float64)
for i in artifact_type_seq:
@@ -806,12 +806,12 @@ class MainWindow_resp_quality_label(QMainWindow):
def __slot_btn_refilter_orgBcg__(self):
PublicFunc.__disableAllButton__(self, ButtonState)
if len(self.data.OrgBCG_Processed) == 0:
- Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
- return
+ return Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
if self.ui.radioButton_orgBcg_fillterMode_custom.isChecked():
if self.check_filter_args() is False:
PublicFunc.msgbox_output(self, Constants.RESP_QUALITY_LABEL_CUSTOM_FILTER_ARGS_ERROR, Constants.MSGBOX_TYPE_ERROR)
+ PublicFunc.finish_operation(self, ButtonState)
return
result = self.__plot__()
if not result.status:
@@ -1036,7 +1036,8 @@ class MainWindow_resp_quality_label(QMainWindow):
self.ax1_spectrum.set_title(Constants.RESP_QUALITY_LABEL_SPECTRUM_THO_TITLE, fontsize=8)
def check_filter_args(self):
- if (float(Config["Filter"]["BandPassLow"]) >= float(Config["Filter"]["BandPassHigh"])):
+ if ((float(Config["Filter"]["BandPassLow"]) >= float(Config["Filter"]["BandPassHigh"])) or
+ (float(Config["Filter"]["BandPassLow"]) <= 0) or (float(Config["Filter"]["BandPassHigh"]) <= 0)):
return False
return True
@@ -1301,7 +1302,7 @@ class Data():
def resample_tho(self):
if self.Tho is None:
- Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
+ return Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
try:
if Config["InputConfig"]["ThoFreq"] != Config["InputConfig"]["ThoUseFreq"]:
@@ -1311,8 +1312,8 @@ class Data():
else:
return Result().success(info=Constants.RESAMPLE_NO_NEED)
except Exception as e:
- Result().failure(info=Constants.RESAMPLE_FAILURE +
- Constants.FAILURE_REASON["Resample_Exception"] + "\n" + format_exc())
+ return Result().failure(info=Constants.RESAMPLE_FAILURE +
+ Constants.FAILURE_REASON["Resample_Exception"] + "\n" + format_exc())
return Result().success(info=Constants.RESAMPLE_FINISHED)
@@ -1353,6 +1354,10 @@ class Data():
try:
DataFrame(self.Tho_peak).to_csv(Path(Config["Path"]["Save_Tho_peak"]), mode='w', index=False, header=False)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Filename.THO_PEAK + Constants.SAVE_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
@@ -1477,7 +1482,7 @@ class Data():
def resample_tho_and_OrgBCG(self):
if (self.OrgBCG is None) or (self.Tho is None):
- Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
+ return Result().failure(info=Constants.RESAMPLE_FAILURE + Constants.FAILURE_REASON["Data_Not_Exist"])
try:
if ((Config["InputConfig"]["OrgBCGFreq"] != Config["InputConfig"]["OrgBCGUseFreq"])
@@ -1494,8 +1499,8 @@ class Data():
else:
return Result().success(info=Constants.RESAMPLE_NO_NEED)
except Exception as e:
- Result().failure(info=Constants.RESAMPLE_FAILURE +
- Constants.FAILURE_REASON["Resample_Exception"] + "\n" + format_exc())
+ return Result().failure(info=Constants.RESAMPLE_FAILURE +
+ Constants.FAILURE_REASON["Resample_Exception"] + "\n" + format_exc())
return Result().success(info=Constants.RESAMPLE_FINISHED)
@@ -1538,6 +1543,10 @@ class Data():
try:
DataFrame(self.resp_quality_label).to_csv(Path(Config["Path"]["Save_Resp_quality_label"]), mode='w', index=False, header=False)
+ except PermissionError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_Permission_Denied"])
+ except FileNotFoundError as e:
+ return Result().failure(info=Constants.SAVE_FAILURE + Constants.FAILURE_REASON["Save_File_Not_Found"])
except Exception as e:
return Result().failure(info=Filename.RESP_QUALITY_LABEL + Constants.SAVE_FAILURE +
Constants.FAILURE_REASON["Save_Exception"] + "\n" + format_exc())
diff --git a/func/utils/Constants.py b/func/utils/Constants.py
index 58c564f..0b7f2cd 100644
--- a/func/utils/Constants.py
+++ b/func/utils/Constants.py
@@ -108,6 +108,10 @@ class Constants:
"Data_Length_not_Correct": "(orgBcg和BCG长度不匹配)",
"Artifact_Format_Not_Correct": "(体动长度或格式不正确)",
"Data_Length_Not_Correct": "(信号长度不正确)",
+ "Filter_Args_Not_Correct": "(滤波器参数输入不正确,上下截止频率都要大于0,且上截止频率应大于下截止频率)",
+ "Interval_Args_Not_Correct": "(间期参数输入不正确,上间期阈值应大于下间期阈值)",
+ "Save_Permission_Denied": "(所保存的文件正在被其他进程使用)",
+ "Save_File_Not_Found": "(保存路径不存在)",
"Open_Data_Exception": "(打开数据异常)",
"Process_Exception": "(处理异常)",
@@ -458,8 +462,8 @@ class Constants:
RESP_QUALITY_LABEL_ADD_POINTS_SUCCESSFULLY: str = "成功新增点,横坐标:"
RESP_QUALITY_LABEL_REMOVE_POINTS_SUCCESSFULLY: str = "成功删除点,横坐标:"
RESP_QUALITY_LABEL_NO_POINT_IN_THE_INTERVAL: str = "所选区间内无新增或删除点"
- RESP_QUALITY_LABEL_CUSTOM_FILTER_ARGS_ERROR: str = "OrgBCG带通滤波频率设置范围应为数字,范围是0~1"
- RESP_QUALITY_LABEL_AUTOLABEL_ARGS_ERROR: str = "人工标注阈值设置范围应为数字,范围是0~1"
+ RESP_QUALITY_LABEL_CUSTOM_FILTER_ARGS_ERROR: str = "OrgBCG带通滤波频率设置范围应为数字,范围是0~1,且上截止频率应大于下截止频率"
+ RESP_QUALITY_LABEL_AUTOLABEL_ARGS_ERROR: str = "人工标注阈值设置范围应为数字,范围是0~1,且[1]应大于[0]"
RESP_QUALITY_LABEL_CHECK_ARGS_QUESTION_CONTENT: str = "你确定要执行此操作吗,请确保参数输入正确"
RESP_QUALITY_LABEL_ACTION_LABEL_MULTIPLE_NAME: str = f"批量更改标签({Params.RESP_QUALITY_LABEL_ACTION_LABEL_MULTIPLE_SHORTCUT_KEY})"
RESP_QUALITY_LABEL_A_QUALITY: int = 1
diff --git a/ui/MainWindow/MainWindow_SA_label.py b/ui/MainWindow/MainWindow_SA_label.py
index 21c196f..4cf694f 100644
--- a/ui/MainWindow/MainWindow_SA_label.py
+++ b/ui/MainWindow/MainWindow_SA_label.py
@@ -143,6 +143,17 @@ class Ui_MainWindow_SA_label(object):
self.verticalLayout_2.addItem(self.verticalSpacer_3)
+ self.pushButton_save = QPushButton(self.groupBox_left)
+ self.pushButton_save.setObjectName(u"pushButton_save")
+ sizePolicy1 = QSizePolicy(QSizePolicy.Policy.Minimum, QSizePolicy.Policy.Preferred)
+ sizePolicy1.setHorizontalStretch(0)
+ sizePolicy1.setVerticalStretch(0)
+ sizePolicy1.setHeightForWidth(self.pushButton_save.sizePolicy().hasHeightForWidth())
+ self.pushButton_save.setSizePolicy(sizePolicy1)
+ self.pushButton_save.setFont(font1)
+
+ self.verticalLayout_2.addWidget(self.pushButton_save)
+
self.groupBox_4 = QGroupBox(self.groupBox_left)
self.groupBox_4.setObjectName(u"groupBox_4")
self.verticalLayout_6 = QVBoxLayout(self.groupBox_4)
@@ -159,7 +170,8 @@ class Ui_MainWindow_SA_label(object):
self.verticalLayout_2.setStretch(1, 1)
self.verticalLayout_2.setStretch(2, 15)
self.verticalLayout_2.setStretch(3, 1)
- self.verticalLayout_2.setStretch(4, 5)
+ self.verticalLayout_2.setStretch(4, 2)
+ self.verticalLayout_2.setStretch(5, 5)
self.gridLayout.addWidget(self.groupBox_left, 0, 0, 1, 1)
@@ -368,9 +380,6 @@ class Ui_MainWindow_SA_label(object):
self.gridLayout_5.setObjectName(u"gridLayout_5")
self.pushButton_quick_remark_input_durationNoEnough = QPushButton(self.groupBox_label_operation)
self.pushButton_quick_remark_input_durationNoEnough.setObjectName(u"pushButton_quick_remark_input_durationNoEnough")
- sizePolicy1 = QSizePolicy(QSizePolicy.Policy.Minimum, QSizePolicy.Policy.Preferred)
- sizePolicy1.setHorizontalStretch(0)
- sizePolicy1.setVerticalStretch(0)
sizePolicy1.setHeightForWidth(self.pushButton_quick_remark_input_durationNoEnough.sizePolicy().hasHeightForWidth())
self.pushButton_quick_remark_input_durationNoEnough.setSizePolicy(sizePolicy1)
self.pushButton_quick_remark_input_durationNoEnough.setFont(font1)
@@ -557,6 +566,7 @@ class Ui_MainWindow_SA_label(object):
self.lineEdit_filter_label_add.setPlaceholderText(QCoreApplication.translate("MainWindow_SA_label", u"\u7b5b\u9009\u5668", None))
self.lineEdit_filter_label.setPlaceholderText(QCoreApplication.translate("MainWindow_SA_label", u"\u7b5b\u9009\u5668", None))
self.label_2.setText(QCoreApplication.translate("MainWindow_SA_label", u"\u65b0\u589e\u7684\u6807\u7b7e", None))
+ self.pushButton_save.setText(QCoreApplication.translate("MainWindow_SA_label", u"\u624b\u52a8\u4fdd\u5b58", None))
self.groupBox_4.setTitle(QCoreApplication.translate("MainWindow_SA_label", u"\u65e5\u5fd7", None))
self.groupBox_right.setTitle(QCoreApplication.translate("MainWindow_SA_label", u"\u7761\u7720\u547c\u5438\u6682\u505c\u4e8b\u4ef6\u6807\u6ce8", None))
self.groupBox_examineBySecond.setTitle(QCoreApplication.translate("MainWindow_SA_label", u"\u9010\u5e27\u68c0\u67e5", None))
diff --git a/ui/MainWindow/MainWindow_SA_label.ui b/ui/MainWindow/MainWindow_SA_label.ui
index 2e35b97..510f787 100644
--- a/ui/MainWindow/MainWindow_SA_label.ui
+++ b/ui/MainWindow/MainWindow_SA_label.ui
@@ -42,7 +42,7 @@
睡眠呼吸暂停事件标注
-
+
-
-
@@ -208,6 +208,24 @@
+ -
+
+
+
+ 0
+ 0
+
+
+
+
+ 12
+
+
+
+ 手动保存
+
+
+
-
diff --git a/ui/MainWindow/MainWindow_menu.py b/ui/MainWindow/MainWindow_menu.py
index 5f7f1ff..104c18a 100644
--- a/ui/MainWindow/MainWindow_menu.py
+++ b/ui/MainWindow/MainWindow_menu.py
@@ -50,6 +50,7 @@ class Ui_Signal_Label(object):
self.plainTextEdit_root_path = QPlainTextEdit(self.centralwidget)
self.plainTextEdit_root_path.setObjectName(u"plainTextEdit_root_path")
+ self.plainTextEdit_root_path.setEnabled(False)
self.verticalLayout_3.addWidget(self.plainTextEdit_root_path)
diff --git a/ui/MainWindow/MainWindow_menu.ui b/ui/MainWindow/MainWindow_menu.ui
index 6189829..5445f16 100644
--- a/ui/MainWindow/MainWindow_menu.ui
+++ b/ui/MainWindow/MainWindow_menu.ui
@@ -40,7 +40,11 @@
-
-
+
+
+ false
+
+