Se eu quiser usar os resultados de argparse.ArgumentParser()
, que é um Namespace
objeto, com um método que espera um dicionário ou um objeto parecido com o mapeamento (consulte collections.Mapping ), qual é a maneira correta de fazer isso?
C:\>python
Python 2.7.3 (default, Apr 10 2012, 23:31:26) [MSC v.1500 32 bit (Intel)] on win
32
Type "help", "copyright", "credits" or "license" for more information.
>>> import argparse
>>> args = argparse.Namespace()
>>> args.foo = 1
>>> args.bar = [1,2,3]
>>> args.baz = 'yippee'
>>> args['baz']
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: 'Namespace' object has no attribute '__getitem__'
>>> dir(args)
['__class__', '__contains__', '__delattr__', '__dict__', '__doc__', '__eq__', '_
_format__', '__getattribute__', '__hash__', '__init__', '__module__', '__ne__',
'__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__
', '__str__', '__subclasshook__', '__weakref__', '_get_args', '_get_kwargs', 'ba
r', 'baz', 'foo']
É apropriado "alcançar" um objeto e usar sua __dict__
propriedade?
Eu acho que a resposta é não: __dict__
cheira como uma convenção para a implementação, mas não para uma interface, a maneira __getattribute__
ou __setattr__
ou __contains__
parecem ser.
python
dictionary
duck-typing
Jason S
fonte
fonte
vars()
(que é umlocals()
ouglobals()
), mas não tenho muita certeza.vars()
e__dict__
/3/
versão dos documentos (em uma inspeção mais detalhada, incluindo 3.1 a 3.4), então a correção está aparentemente ausente.Diretamente da boca do cavalo :
fonte
vars(args)
me dáTypeError: 'dict' object is not callable
vars
por uma variável. Você pode usar__builtins__.vars
para acessá-lo diretamente oudel vars
parar de sombrear.del
. No âmbito do módulodel
irá trabalhar para builtins "un-sombra".Em geral, eu diria "não". No entanto
Namespace
, me pareceu um excesso de engenharia, possivelmente a partir de quando as classes não puderam herdar dos tipos internos.Por outro lado,
Namespace
apresenta uma abordagem orientada a tarefas para o argparse, e não consigo pensar em uma situação que exigiria agarrá-lo__dict__
, mas os limites da minha imaginação não são os mesmos que os seus.fonte
do_something(**args.__dict__)