RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1590860
Accepted
alexandrov
alexandrov
Asked:2024-08-16 02:31:04 +0000 UTC2024-08-16 02:31:04 +0000 UTC 2024-08-16 02:31:04 +0000 UTC

模块化 YAML 重置系统

  • 772

有一段代码可以将文件中的设置重置YAML为最初安装程序时的设置。但现在代码只能重置一个类,而增加数量的问题是我不知道如何利用ООПpython 的功能来紧凑地完成它。如何实施?

设置.py:

from abc import ABC, abstractmethod
from dataclasses import dataclass
from pathlib import Path
from enum import Enum

import yaml

from src.settings.default_settings import JetInjectorConstant, CentrifugalInjectorConstant


class ListNameSettingsFile(Enum):
    """
    РУС: Список файлов конфигурации
    ENG: List of configuration files
    """
    LIST_NAME_SETTINGS_FILE = ["injector_settings"]


@dataclass(frozen=True)
class Settings(ABC):
    """
    РУС: Основной класс для обработки файлов конфигурации
    ENG: The main class for processing configuration files
    """
    @staticmethod
    def get_root_dir():
        """
        РУС: Директория установки ПО
        ENG: The software installation directory
        """
        return Path(__file__).absolute().parent

    @abstractmethod
    def get_data_for_recording(self) -> dict:
        """
        РУС: Получение данных для загрузки в файл конфигурации
        ENG: Getting data to upload to a configuration file
        """
        raise NotImplementedError("Данные настроек не загружены")

    @abstractmethod
    def name_settings_file(self) -> str:
        """
        РУС: Получение имени файла конфигурации
        ENG: Getting the name of the configuration file
        """
        raise NotImplementedError("Имя файла настроек не загружено")

    @property
    def save_settings(self) -> None:
        """
        РУС: Запись констант в файл конфигурации
        ENG: Writing constants to a configuration file
        """
        with open((self.get_root_dir() / "data").joinpath(self.name_settings_file() + ".yaml"), "w") as outfile:
            new_dump = yaml.dump(self.get_data_for_recording())
            outfile.write(new_dump)
        return None

    @property
    def read_settings(self) -> dict | None:
        """
        РУС: Чтение констант из файла конфигурации
        ENG: Reading constants from a configuration file
        """
        try:
            with open((self.get_root_dir() / "data").joinpath(self.name_settings_file() + ".yaml"), "r") as stream:
                read_date = yaml.safe_load(stream)
            return read_date
        except FileNotFoundError:
            return InjectorSettings.reset_to_default()


@dataclass(frozen=True)
class InjectorSettings(Settings):
    """
    РУС: Класс констант для проведения расчетов
    ENG: A class of constants for performing calculations
    """
    laminar: float | None = None
    turbulent: float | None = None
    right_angle: float | None = None

    def get_data_for_recording(self) -> dict:
        """
        РУС: Загрузка констант для расчетов
        ENG: Loading constants for calculations
        """
        injector_settings = {
            "reynolds": {"laminar": self.laminar, "turbulent": self.turbulent},
            "right_angle": self.right_angle,
        }
        return injector_settings

    def name_settings_file(self) -> str:
        """
        РУС: Передача имени файла конфигурации
        ENG: Passing the name of the configuration file
        """
        return ListNameSettingsFile.LIST_NAME_SETTINGS_FILE.value[0]

    @staticmethod
    def reset_to_default() -> None:
        """
        РУС: Восстановление значений по умолчанию и запись их в файл конфигурации
        ENG: Resetting to default values and saving them to the configuration file
        """
        default_settings = InjectorSettings(
            laminar=JetInjectorConstant.LAMINAR.value,
            turbulent=JetInjectorConstant.TURBULENT.value,
            right_angle=CentrifugalInjectorConstant.RIGHT_ANGLE.value
        )

        return default_settings.save_settings

默认设置.py:

from enum import Enum


class JetInjectorConstant(Enum):
    """Стандартные значение констант струйной """
    LAMINAR = 2000
    TURBULENT = 10_000


class CentrifugalInjectorConstant(Enum):
    """Стандартные значение констант центробежной форсунки"""
    RIGHT_ANGLE = 90

代码说明:我们有一个主类Settings,其中包含读写文件的函数,还有一个类InjectorSettings,包含与加载计算数据相关的操作。但是,假设我们要添加另一个类,那么我们用于重置设置的代码将不起作用,因为在异常Settings函数的类中没有错误文件的定义。read_settings

python
  • 1 1 个回答
  • 24 Views

1 个回答

  • Voted
  1. Best Answer
    alexandrov
    2024-08-22T01:31:06Z2024-08-22T01:31:06Z

    因此,为了创建这样的结构,您需要求助于创建@abstractmethod,然后我们编写一个与用于处理代码中所有其余功能的模板相同的模板: settings.py:

    from abc import ABC, abstractmethod
    from dataclasses import dataclass
    from pathlib import Path
    from enum import Enum
    
    import yaml
    
    from src.settings.default_settings import JetInjectorConstant, CentrifugalInjectorConstant
    
    
    class ListNameSettingsFile(Enum):
        """
        РУС: Список файлов конфигурации
        ENG: List of configuration files
        """
        LIST_NAME_SETTINGS_FILE = ["injector_settings"]
    
    
    @dataclass(frozen=True)
    class Settings(ABC):
        """
        РУС: Основной класс для обработки файлов конфигурации
        ENG: The main class for processing configuration files
        """
        @staticmethod
        def get_root_dir():
            """
            РУС: Директория установки ПО
            ENG: The software installation directory
            """
            return Path(__file__).absolute().parent
    
        @abstractmethod
        def get_data_for_recording(self) -> dict:
            """
            РУС: Получение данных для загрузки в файл конфигурации
            ENG: Getting data to upload to a configuration file
            """
            raise NotImplementedError("Данные настроек не загружены")
    
        @abstractmethod
        def name_settings_file(self) -> str:
            """
            РУС: Получение имени файла конфигурации
            ENG: Getting the name of the configuration file
            """
            raise NotImplementedError("Имя файла настроек не загружено")
    
        @abstractmethod
        def reset_to_default(self) -> dict:
            """
            РУС: Получение стандартных значений файлов настроек
            ENG: Getting the standard values of the settings files
            """
            raise NotImplementedError("Данные стандартных настроек не загружены")
    
        @property
        def save_settings(self) -> None:
            """
            РУС: Запись констант в файл конфигурации
            ENG: Writing constants to a configuration file
            """
            with open((self.get_root_dir() / "data").joinpath(self.name_settings_file() + ".yaml"), "w") as outfile:
                new_dump = yaml.dump(self.get_data_for_recording())
                outfile.write(new_dump)
            return None
    
        @property
        def read_settings(self) -> dict | None:
            """
            РУС: Чтение констант из файла конфигурации
            ENG: Reading constants from a configuration file
            """
            try:
                with open((self.get_root_dir() / "data").joinpath(self.name_settings_file() + ".yaml"), "r") as stream:
                    read_date = yaml.safe_load(stream)
                return read_date
            except FileNotFoundError:
                return self.reset_to_default().save_settings
    
    
    @dataclass(frozen=True)
    class InjectorSettings(Settings):
        """
        РУС: Класс констант для проведения расчетов
        ENG: A class of constants for performing calculations
        """
        laminar: float | None = None
        turbulent: float | None = None
        right_angle: float | None = None
    
        def get_data_for_recording(self) -> dict:
            """
            РУС: Загрузка констант для расчетов
            ENG: Loading constants for calculations
            """
            injector_settings = {
                "reynolds": {"laminar": self.laminar, "turbulent": self.turbulent},
                "right_angle": self.right_angle,
            }
            return injector_settings
    
        def name_settings_file(self) -> str:
            """
            РУС: Передача имени файла конфигурации
            ENG: Passing the name of the configuration file
            """
            return ListNameSettingsFile.LIST_NAME_SETTINGS_FILE.value[0]
    
        def reset_to_default(self) -> dict:
            """
            РУС: Восстановление значений по умолчанию и запись их в файл конфигурации
            ENG: Resetting to default values and saving them to the configuration file
            """
    
            injector_settings_default = {
                "reynolds": {"laminar": JetInjectorConstant.LAMINAR.value,
                             "turbulent": JetInjectorConstant.TURBULENT.value},
                "right_angle": CentrifugalInjectorConstant.RIGHT_ANGLE.value,
            }
            return injector_settings_default
    

    也许在这种情况下,有一些结构可以显着使代码更易于理解及其体积,但对于我自己来说,我找到了这样的解决方案。

    • 0

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5