RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / user-612923

alexandrov's questions

Martin Hope
alexandrov
Asked: 2024-08-16 02:31:04 +0000 UTC

模块化 YAML 重置系统

  • 6

有一段代码可以将文件中的设置重置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 个回答
  • 24 Views
Martin Hope
alexandrov
Asked: 2024-08-13 22:06:29 +0000 UTC

如何将 YAML 文件中的设置重置为默认值?

  • 8

我编写了一个可以读取数据并将数据写入 .yaml 文件的程序。但现在我面临着将重置设置功能组织为标准的问题。我不知道如何在我的代码中最好地做到这一点...组织这样一个易于理解且简洁的函数的最佳方法是什么?

主要代码文件(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("Имя файла настроек не загружено")

    @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:
        """
        РУС: Чтение констант из файла конфигурации
        ENG: Reading constants from a configuration file
        """
        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


@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]

具有标准设置的文件(default_settings.py):

from enum import Enum


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


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

更新:

在这个项目结构中,我们不是将数据存储在文件中default_settings.yaml,而是将数据存储在文件中default_settings.py,如果不小心删除了这样的文件.yaml,这将导致软件彻底崩溃,如果在程序内部发现了这些数据,将能够恢复其运作。

该文件settings.yaml将存储负责计算边界和启动程序的设置的设置。它们在程序启动时使用一次,并且不会进一步使用。也就是说,如果您在运行期间更改它们,这不会以任何方式影响程序的运行。

需要设置重置系统,以便如果输入了错误的数据,可以返回到程序安装状态(标准设置)。如果在尝试打开文件时,由于文件结构损坏或与无法打开或读取文件相关的其他错误而导致程序无法执行此操作,也会激活重置系统。

python
  • 1 个回答
  • 41 Views
Martin Hope
alexandrov
Asked: 2024-08-09 02:59:33 +0000 UTC

如何使用 Enum 正确地将数据存储在类中?

  • 5

我使用Enum常量进行存储,但我面临这样一个事实:我的常量总体上类型相似,但需要在不同的类中分开。我是这样写代码的,但是有没有更简洁的解决方案呢?

from enum import Enum


class DefaultInjectorConstant(Enum):
    """Класс хранящий все константы связанные с расчетом форсунок"""
    class DefaultJetInjector(Enum):
        """Стандартные значение констант струйной """
        LAMINAR = 2000
        TURBULENT = 10_000

    class DefaultCentrifugalInjector(Enum):
        """Стандартные значение констант центробежной форсунки"""
        RIGHT_ANGLE = 90
    
python
  • 2 个回答
  • 50 Views
Martin Hope
alexandrov
Asked: 2024-08-08 17:00:58 +0000 UTC

如何设置整个Python文件的小数位数?

  • 5

为了设置小数位数,Python通常使用 的方法round,但只能用一个变量来实现。有没有办法在文件开头指定带有小数位的数量?那么在此之后所有计算都使用固定数量的字符?

python
  • 1 个回答
  • 49 Views
Martin Hope
alexandrov
Asked: 2024-08-07 21:24:09 +0000 UTC

如何修复 PyCharm 中的抽象方法警告?

  • 5

我正在Python使用该库编写代码YAML。我编写了一个代码,其中有一个类,ConstantHandler其中有一个函数record_constants接收需要加载到文件中的数据YAML。由于数据是从另一个传输的InjectorConstants,所以我通过抽象方法传输它record_date,一切似乎都很好,但PyCharm它给出了一个警告:Class InjectorConstants must implement all abstract methods。

如何修复它?程序代码:

from dataclasses import dataclass
from pathlib import Path

import yaml
from abc import ABC, abstractmethod


@dataclass(frozen=True)
class ConstantHandler(ABC):
    configuration_file: str

    @staticmethod
    def get_root_dir():
        """Нахождение директории установки ПО"""
        return Path(__file__).absolute().parent

    @abstractmethod
    def record_date(self) -> dict:
        """"""
        raise NotImplementedError

    def record_constants(self):
        """Загрузка расчетных и программных констант в файл конфигурации"""
        with open(self.get_root_dir()/self.configuration_file, "w") as outfile:
            new_dump = yaml.dump(self.record_date())
            outfile.write(new_dump)

    @property
    def read_constants(self) -> dict:
        """Чтение констант из файла конфигурации"""
        with open(self.get_root_dir()/self.configuration_file, "r") as stream:
            injector_constants = yaml.safe_load(stream)
            return injector_constants


@dataclass(frozen=True)
class InjectorConstants(ConstantHandler):
    laminar: float
    turbulent: float
    right_angle: float

    @property
    def record_calculated_constants(self) -> dict:
        """Загрузка значений констант для определения границ расчета"""
        injector_constants = {
            "reynolds": {"laminar": self.laminar, "turbulent": self.turbulent},
            "right_angle": self.right_angle,
        }
        return injector_constants
python
  • 1 个回答
  • 21 Views

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