Jeśli chcę użyć wyników argparse.ArgumentParser()
, czyli Namespace
obiektu, z metodą, która oczekuje na słownik lub obiekt podobny do odwzorowania (patrz kolekcje.Mapowanie ), jaki jest właściwy sposób?
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']
Czy właściwe jest „sięganie” do obiektu i korzystanie z jego __dict__
właściwości?
Myślę, że odpowiedź nie jest: __dict__
pachnie konwencji do realizacji, ale nie dla interfejsu, sposób __getattribute__
lub __setattr__
czy __contains__
wydają się być.
python
dictionary
duck-typing
Jason S.
źródło
źródło
vars()
(które jest albolocals()
alboglobals()
), ale nie jestem do końca pewien.vars()
i__dict__
/3/
wersji dokumentów (po dokładniejszej inspekcji, od 3.1 do 3.4 włącznie), więc widocznie tam brakuje korekty.Prosto z pyska konia :
źródło
vars(args)
daje miTypeError: 'dict' object is not callable
vars
zmienną. Możesz użyć,__builtins__.vars
aby uzyskać do niego bezpośredni dostęp lubdel vars
przestać go ukrywać.del
. W module modułdel
będzie działał do „un-shadow” wbudowanych.Ogólnie powiedziałbym „nie”. Jednak
Namespace
wydało mi się, że jestem zbyt zaawansowany, prawdopodobnie z tego, że klasy nie mogły dziedziczyć po wbudowanych typach.Z drugiej strony,
Namespace
przedstawia podejście zorientowane na zadania do arsenału i nie mogę wymyślić sytuacji, która wymagałaby złapania się__dict__
, ale granice mojej wyobraźni nie są takie same jak twoje.źródło
do_something(**args.__dict__)