本文整理匯總了Python中inspect.Parameter.VAR_KEYWORD屬性的典型用法代碼示例。如果您正苦於以下問題:Python Parameter.VAR_KEYWORD屬性的具體用法?Python Parameter.VAR_KEYWORD怎麽用?Python Parameter.VAR_KEYWORD使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類inspect.Parameter
的用法示例。
在下文中一共展示了Parameter.VAR_KEYWORD屬性的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: auto_assign
# 需要導入模塊: from inspect import Parameter [as 別名]
# 或者: from inspect.Parameter import VAR_KEYWORD [as 別名]
def auto_assign(func):
# Signature:
sig = signature(func)
for name, param in sig.parameters.items():
if param.kind in (Parameter.VAR_POSITIONAL, Parameter.VAR_KEYWORD):
raise RuntimeError('Unable to auto assign if *args or **kwargs in signature.')
# Wrapper:
@functools.wraps(func)
def wrapper(self, *args, **kwargs):
for i, (name, param) in enumerate(sig.parameters.items()):
# Skip 'self' param:
if i == 0: continue
# Search value in args, kwargs or defaults:
if i - 1 < len(args):
val = args[i - 1]
elif name in kwargs:
val = kwargs[name]
else:
val = param.default
setattr(self, name, val)
func(self, *args, **kwargs)
return wrapper
示例2: _yield_abbreviations_for_parameter
# 需要導入模塊: from inspect import Parameter [as 別名]
# 或者: from inspect.Parameter import VAR_KEYWORD [as 別名]
def _yield_abbreviations_for_parameter(param, kwargs):
"""Get an abbreviation for a function parameter."""
name = param.name
kind = param.kind
ann = param.annotation
default = param.default
not_found = (name, empty, empty)
if kind in (Parameter.POSITIONAL_OR_KEYWORD, Parameter.KEYWORD_ONLY):
if name in kwargs:
value = kwargs.pop(name)
elif ann is not empty:
warn("Using function annotations to implicitly specify interactive controls is deprecated. Use an explicit keyword argument for the parameter instead.", DeprecationWarning)
value = ann
elif default is not empty:
value = default
else:
yield not_found
yield (name, value, default)
elif kind == Parameter.VAR_KEYWORD:
# In this case name=kwargs and we yield the items in kwargs with their keys.
for k, v in kwargs.copy().items():
kwargs.pop(k)
yield k, v, empty
示例3: getargspec
# 需要導入模塊: from inspect import Parameter [as 別名]
# 或者: from inspect.Parameter import VAR_KEYWORD [as 別名]
def getargspec(func):
signature = inspect.signature(func)
args = []
varargs = None
keywords = None
defaults = []
for param in signature.parameters.values(): # type: Parameter
if param.kind == Parameter.VAR_POSITIONAL:
varargs = param.name
elif param.kind in (
Parameter.POSITIONAL_ONLY,
Parameter.KEYWORD_ONLY,
Parameter.POSITIONAL_OR_KEYWORD):
args.append(param.name)
elif param.kind == Parameter.VAR_KEYWORD:
keywords = param.name
# noinspection PyProtectedMember
if param.default is not inspect._empty:
defaults.append(param.default)
return ArgSpec(args, varargs, keywords, tuple(defaults))
示例4: accept_variable_arguments
# 需要導入模塊: from inspect import Parameter [as 別名]
# 或者: from inspect.Parameter import VAR_KEYWORD [as 別名]
def accept_variable_arguments(func):
for param in signature(func).parameters.values():
if param.kind in (Parameter.VAR_POSITIONAL,
Parameter.VAR_KEYWORD):
return True
return False
示例5: get_argspec
# 需要導入模塊: from inspect import Parameter [as 別名]
# 或者: from inspect.Parameter import VAR_KEYWORD [as 別名]
def get_argspec(f):
sig = inspect.signature(f)
args = [n for n, p in sig.parameters.items() if p.kind in ARG_TYPES]
pos_args = [
n
for n, p in sig.parameters.items()
if p.kind in POSARG_TYPES and p.default == inspect._empty
]
varargs = [
n for n, p in sig.parameters.items() if p.kind == Parameter.VAR_POSITIONAL
]
# only use first vararg (how on earth would you have more anyways?)
vararg_name = varargs[0] if varargs else None
varkws = [n for n, p in sig.parameters.items() if p.kind == Parameter.VAR_KEYWORD]
# only use first varkw (how on earth would you have more anyways?)
kw_wildcard_name = varkws[0] if varkws else None
kwargs = OrderedDict(
[
(n, p.default)
for n, p in sig.parameters.items()
if p.default != inspect._empty
]
)
return args, vararg_name, kw_wildcard_name, pos_args, kwargs
示例6: has_var_keyword
# 需要導入模塊: from inspect import Parameter [as 別名]
# 或者: from inspect.Parameter import VAR_KEYWORD [as 別名]
def has_var_keyword(sig):
return any(p for n, p in sig.parameters.items()
if p.kind is Parameter.VAR_KEYWORD)
示例7: _convert_from_parameter_kind
# 需要導入模塊: from inspect import Parameter [as 別名]
# 或者: from inspect.Parameter import VAR_KEYWORD [as 別名]
def _convert_from_parameter_kind(kind):
if kind == Parameter.POSITIONAL_ONLY:
return 0
if kind == Parameter.POSITIONAL_OR_KEYWORD:
return 1
if kind == Parameter.VAR_POSITIONAL:
return 2
if kind == Parameter.KEYWORD_ONLY:
return 3
if kind == Parameter.VAR_KEYWORD:
return 4
示例8: test_viewable_signature
# 需要導入模塊: from inspect import Parameter [as 別名]
# 或者: from inspect.Parameter import VAR_KEYWORD [as 別名]
def test_viewable_signature(viewable):
from inspect import Parameter, signature
parameters = signature(viewable).parameters
assert 'params' in parameters
assert parameters['params'] == Parameter('params', Parameter.VAR_KEYWORD)
示例9: _yield_abbreviations_for_parameter
# 需要導入模塊: from inspect import Parameter [as 別名]
# 或者: from inspect.Parameter import VAR_KEYWORD [as 別名]
def _yield_abbreviations_for_parameter(parameter, kwargs):
"""Get an abbreviation for a function parameter."""
name = parameter.name
kind = parameter.kind
ann = parameter.annotation
default = parameter.default
not_found = (name, empty, empty)
if kind in (Parameter.POSITIONAL_OR_KEYWORD, Parameter.KEYWORD_ONLY):
if name in kwargs:
value = kwargs.pop(name)
elif ann is not empty:
param.main.warning("Using function annotations to implicitly specify interactive controls is deprecated. "
"Use an explicit keyword argument for the parameter instead.", DeprecationWarning)
value = ann
elif default is not empty:
value = default
if isinstance(value, (Iterable, Mapping)):
value = fixed(value)
else:
yield not_found
yield (name, value, default)
elif kind == Parameter.VAR_KEYWORD:
# In this case name=kwargs and we yield the items in kwargs with their keys.
for k, v in kwargs.copy().items():
kwargs.pop(k)
yield k, v, empty
示例10: _apply_signatures
# 需要導入模塊: from inspect import Parameter [as 別名]
# 或者: from inspect.Parameter import VAR_KEYWORD [as 別名]
def _apply_signatures(self):
from inspect import Parameter, Signature
from .viewable import Viewable
descendants = param.concrete_descendents(Viewable)
for cls in reversed(list(descendants.values())):
if cls.__doc__.startswith('params'):
prefix = cls.__doc__.split('\n')[0]
cls.__doc__ = cls.__doc__.replace(prefix, '')
sig = inspect.signature(cls.__init__)
sig_params = list(sig.parameters.values())
if not sig_params or sig_params[-1] != Parameter('params', Parameter.VAR_KEYWORD):
continue
parameters = sig_params[:-1]
processed_kws, keyword_groups = set(), []
for cls in reversed(cls.mro()):
keyword_group = []
for (k, v) in sorted(cls.__dict__.items()):
if (isinstance(v, param.Parameter) and k not in processed_kws
and not v.readonly):
keyword_group.append(k)
processed_kws.add(k)
keyword_groups.append(keyword_group)
parameters += [
Parameter(name, Parameter.KEYWORD_ONLY)
for kws in reversed(keyword_groups) for name in kws
if name not in sig.parameters
]
parameters.append(Parameter('kwargs', Parameter.VAR_KEYWORD))
cls.__init__.__signature__ = Signature(
parameters, return_annotation=sig.return_annotation
)
#---------------------------------------------------------------------
# Private API
#---------------------------------------------------------------------
示例11: generate_model_signature
# 需要導入模塊: from inspect import Parameter [as 別名]
# 或者: from inspect.Parameter import VAR_KEYWORD [as 別名]
def generate_model_signature(
init: Callable[..., None], fields: Dict[str, 'ModelField'], config: Type['BaseConfig']
) -> 'Signature':
"""
Generate signature for model based on its fields
"""
from inspect import Parameter, Signature, signature
present_params = signature(init).parameters.values()
merged_params: Dict[str, Parameter] = {}
var_kw = None
use_var_kw = False
for param in islice(present_params, 1, None): # skip self arg
if param.kind is param.VAR_KEYWORD:
var_kw = param
continue
merged_params[param.name] = param
if var_kw: # if custom init has no var_kw, fields which are not declared in it cannot be passed through
allow_names = config.allow_population_by_field_name
for field_name, field in fields.items():
param_name = field.alias
if field_name in merged_params or param_name in merged_params:
continue
elif not param_name.isidentifier():
if allow_names and field_name.isidentifier():
param_name = field_name
else:
use_var_kw = True
continue
# TODO: replace annotation with actual expected types once #1055 solved
kwargs = {'default': field.default} if not field.required else {}
merged_params[param_name] = Parameter(
param_name, Parameter.KEYWORD_ONLY, annotation=field.outer_type_, **kwargs
)
if config.extra is config.extra.allow:
use_var_kw = True
if var_kw and use_var_kw:
# Make sure the parameter for extra kwargs
# does not have the same name as a field
default_model_signature = [
('__pydantic_self__', Parameter.POSITIONAL_OR_KEYWORD),
('data', Parameter.VAR_KEYWORD),
]
if [(p.name, p.kind) for p in present_params] == default_model_signature:
# if this is the standard model signature, use extra_data as the extra args name
var_kw_name = 'extra_data'
else:
# else start from var_kw
var_kw_name = var_kw.name
# generate a name that's definitely unique
while var_kw_name in fields:
var_kw_name += '_'
merged_params[var_kw_name] = var_kw.replace(name=var_kw_name)
return Signature(parameters=list(merged_params.values()), return_annotation=None)