當前位置: 首頁>>代碼示例>>Python>>正文


Python dataclasses.field方法代碼示例

本文整理匯總了Python中dataclasses.field方法的典型用法代碼示例。如果您正苦於以下問題:Python dataclasses.field方法的具體用法?Python dataclasses.field怎麽用?Python dataclasses.field使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在dataclasses的用法示例。


在下文中一共展示了dataclasses.field方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_validate

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def test_validate():
    @dataclass
    class Config:
        foo: Optional[float] = field(
            default=None,
            metadata={
                'validate': _optional(_chain(_of_type(int, float), _positive)),
            },
        )

        def __post_init__(self):
            _validate(self)

    assert Config().foo is None
    assert Config(foo=0.123).foo == 0.123
    assert Config(foo=42).foo == 42

    with pytest.raises(ValueError, match='"foo" should be positive'):
        assert Config(foo=0)

    with pytest.raises(TypeError, match='"foo" should be of type'):
        assert Config(foo='a') 
開發者ID:vmagamedov,項目名稱:grpclib,代碼行數:24,代碼來源:test_config.py

示例2: test_change_default

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def test_change_default():
    # all params should be optional
    @dataclass
    class Config:
        foo: Optional[float] = field(
            default=cast(None, _DEFAULT),
            metadata={
                'validate': _optional(_chain(_of_type(int, float), _positive)),
                'test-default': 1234,
            },
        )

        def __post_init__(self):
            _validate(self)

    assert _with_defaults(Config(foo=1), 'test-default').foo == 1 
開發者ID:vmagamedov,項目名稱:grpclib,代碼行數:18,代碼來源:test_config.py

示例3: field

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def field(
    description: str,
    *args,
    action=None,
    required: bool = False,
    labeled: bool = False,
    metadata: Optional[dict] = None,
    **kwargs,
):
    """
    Creates an instance of :py:func:`dataclasses.field`. The first argument,
    ``description`` is the description of the field, and will be set as the
    ``"description"`` key in the metadata ``dict``.
    """
    if not metadata:
        metadata = {}
    metadata["description"] = description
    metadata["required"] = required
    metadata["labeled"] = labeled
    metadata["action"] = action
    return dataclasses.field(*args, metadata=metadata, **kwargs) 
開發者ID:intel,項目名稱:dffml,代碼行數:23,代碼來源:base.py

示例4: config

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def config(cls, config, *above):
        """
        Create the BaseConfig required to instantiate this class by parsing the
        config dict.
        """
        if getattr(cls, "CONFIG", None) is None:
            raise AttributeError(
                f"{cls.__qualname__} requires CONFIG property or implementation of config() classmethod"
            )
        # Build the arguments to the CONFIG class
        kwargs: Dict[str, Any] = {}
        for field in dataclasses.fields(cls.CONFIG):
            kwargs[field.name] = got = cls.config_get(
                config, above, field.name
            )
            if inspect.isclass(got) and issubclass(got, BaseConfigurable):
                try:
                    kwargs[field.name] = got.withconfig(
                        config, *above, *cls.add_label()
                    )
                except MissingConfig:
                    kwargs[field.name] = got.withconfig(
                        config, *above, *cls.add_label()[:-1]
                    )
        return cls.CONFIG(**kwargs) 
開發者ID:intel,項目名稱:dffml,代碼行數:27,代碼來源:base.py

示例5: test_modifiers

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def test_modifiers() -> None:
    conf: Modifiers = OmegaConf.structured(Modifiers)
    # regular fields cannot take None
    with pytest.raises(ValidationError):
        conf.num = None  # type: ignore

    # but Optional fields can
    conf.optional_num = None
    assert conf.optional_num is None

    # Accessing a missing field will trigger MissingMandatoryValue exception
    with pytest.raises(MissingMandatoryValue):
        # noinspection PyStatementEffect
        conf.another_num

    # but you can access it once it's been assigned
    conf.another_num = 42
    assert conf.another_num == 42 
開發者ID:omry,項目名稱:omegaconf,代碼行數:20,代碼來源:test_dataclass_example.py

示例6: constant_field

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def constant_field(**kwargs):
    """Marks a flow field as constant.

    Constant flow fields are not permitted to change value once set, and
    consequently, the gradient for these fields do not exist.

    Args:
        kwargs: Keyword arguments to pass to `dataclasses.field`.

    Returns:
        A dataclasses field where `metadata` has entry `"constant_field": True`.
    """
    if "metadata" not in kwargs:
        kwargs["metadata"] = {}
    kwargs["metadata"].update({"constant_field": True})
    return dataclasses.field(**kwargs) 
開發者ID:stanfordnqp,項目名稱:spins-b,代碼行數:18,代碼來源:flows.py

示例7: with_context

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def with_context(self, *, collisions: FrozenSet[str]) -> 'Field':
        """Return a derivative of this field with the provided context.

        This method is used to address naming collisions. The returned
        ``Field`` object aliases module names to avoid naming collisions
        in the file being written.
        """
        return dataclasses.replace(
            self,
            message=self.message.with_context(
                collisions=collisions,
                skip_fields=True,
            ) if self.message else None,
            enum=self.enum.with_context(collisions=collisions)
            if self.enum else None,
            meta=self.meta.with_context(collisions=collisions),
        ) 
開發者ID:googleapis,項目名稱:gapic-generator-python,代碼行數:19,代碼來源:wrappers.py

示例8: recursive_field_types

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def recursive_field_types(self) -> Sequence[
        Union['MessageType', 'EnumType']
    ]:
        """Return all composite fields used in this proto's messages."""
        types: Set[Union['MessageType', 'EnumType']] = set()

        stack = [iter(self.fields.values())]
        while stack:
            fields_iter = stack.pop()
            for field in fields_iter:
                if field.message and field.type not in types:
                    stack.append(iter(field.message.fields.values()))
                if not field.is_primitive:
                    types.add(field.type)

        return tuple(types) 
開發者ID:googleapis,項目名稱:gapic-generator-python,代碼行數:18,代碼來源:wrappers.py

示例9: field_headers

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def field_headers(self) -> Sequence[str]:
        """Return the field headers defined for this method."""
        http = self.options.Extensions[annotations_pb2.http]

        pattern = re.compile(r'\{([a-z][\w\d_.]+)=')

        potential_verbs = [
            http.get,
            http.put,
            http.post,
            http.delete,
            http.patch,
            http.custom.path,
        ]

        return next((tuple(pattern.findall(verb)) for verb in potential_verbs if verb), ()) 
開發者ID:googleapis,項目名稱:gapic-generator-python,代碼行數:18,代碼來源:wrappers.py

示例10: paged_result_field

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def paged_result_field(self) -> Optional[Field]:
        """Return the response pagination field if the method is paginated."""
        # If the request field lacks any of the expected pagination fields,
        # then the method is not paginated.
        for page_field in ((self.input, int, 'page_size'),
                           (self.input, str, 'page_token'),
                           (self.output, str, 'next_page_token')):
            field = page_field[0].fields.get(page_field[2], None)
            if not field or field.type != page_field[1]:
                return None

        # Return the first repeated field.
        for field in self.output.fields.values():
            if field.repeated and field.message:
                return field

        # We found no repeated fields. Return None.
        return None 
開發者ID:googleapis,項目名稱:gapic-generator-python,代碼行數:20,代碼來源:wrappers.py

示例11: message_factory

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def message_factory(exp: str,
                    repeated_iter=itertools.repeat(False),
                    enum: Optional[wrappers.EnumType] = None) -> DummyMessage:
    # This mimics the structure of MessageType in the wrappers module:
    # A MessageType has a map from field names to Fields,
    # and a Field has an (optional) MessageType.
    # The 'exp' parameter is a dotted attribute expression
    # used to describe the field and type hierarchy,
    # e.g. "mollusc.cephalopod.coleoid"
    toks = exp.split(".")
    messages = [DummyMessage({}, tok.upper() + "_TYPE") for tok in toks]
    if enum:
        messages[-1] = enum

    for base, field, attr_name, repeated_field in zip(
        messages, messages[1:], toks[1:], repeated_iter
    ):
        base.fields[attr_name] = (DummyField(message=field, repeated=repeated_field)
                                  if isinstance(field, DummyMessage)
                                  else DummyField(enum=field))

    return messages[0] 
開發者ID:googleapis,項目名稱:gapic-generator-python,代碼行數:24,代碼來源:common_types.py

示例12: test_from_dict_with_wrong_type

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def test_from_dict_with_wrong_type():
    @dataclass
    class X:
        s: str
        i: int

    with pytest.raises(WrongTypeError) as exception_info:
        from_dict(X, {"s": "test", "i": "wrong"})

    assert (
        str(exception_info.value)
        == 'wrong value type for field "i" - should be "int" instead of value "wrong" of type "str"'
    )
    assert exception_info.value.field_path == "i"
    assert exception_info.value.field_type == int
    assert exception_info.value.value == "wrong" 
開發者ID:konradhalas,項目名稱:dacite,代碼行數:18,代碼來源:test_base.py

示例13: __set_id__

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def __set_id__(cls, instance: t.Any, id_value: IdType = None) -> t.Any:
        """Implements technical details of setting an ID value to the field.""" 
開發者ID:pcah,項目名稱:python-clean-architecture,代碼行數:4,代碼來源:entity.py

示例14: __init_subclass__

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def __init_subclass__(cls, **kwargs):
        super().__init_subclass__(**kwargs)
        id_fields = [(k, v) for k, v in cls.__dict__.items() if isinstance(v, Id)]
        if not getattr(cls, '__id_field_name__', None):
            assert len(id_fields) == 1, (
                f"Exactly one ID field is required for any Entity class. Got: "
                f"{dict(id_fields) if id_fields else None}"
            )
            cls.__id_field_name__ = id_fields[0][0]
        return dataclasses.dataclass(cls, eq=False) 
開發者ID:pcah,項目名稱:python-clean-architecture,代碼行數:12,代碼來源:entity.py

示例15: __get_id_field__

# 需要導入模塊: import dataclasses [as 別名]
# 或者: from dataclasses import field [as 別名]
def __get_id_field__(cls) -> Id:
        """Returns the field assumed to be the identity descriptor."""
        return getattr(cls, cls.__id_field_name__) 
開發者ID:pcah,項目名稱:python-clean-architecture,代碼行數:5,代碼來源:entity.py


注:本文中的dataclasses.field方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。