Is vars() the most useless Python built-in ever?

Peter Otten __peter__ at web.de
Tue Dec 1 05:40:15 EST 2015


Manolo Martínez wrote:
> On 12/01/15 at 12:00pm, Steven D'Aprano wrote:
> > I'm trying to understand why vars() exists. Does anyone use it?
>> Well, I have this little podcast aggregator
> (https://github.com/manolomartinez/greg) that I and a bunch of other
> people use. I started writing it some years ago, and the code is a bit
> of a palimpsest, newer functionality reflecting my (somewhat) better
> understanding of the language. One of the oldest bits is this main()
> function:
>> def main(): # parse the args and call whatever function was 
selected
> try:
> args = parser.parse_args(sys.argv[1:])
> args.func(vars(args))
> except AttributeError as err:
> if str(err) == "\'Namespace\' object has no 
attribute \'func\'":
> parser.print_help()
> else:
> print("Something has gone wrong: 
{}".format(err), file = sys.stderr, flush = True)
>>> To judge by this thread, this is probably wrong/noobish?

What probably is typical for a beginner in that snippet is that you don't 
trust the exception system and handle exceptions that will never occur once 
the script is debugged. Just write
args = parser.parse_args()
args.func(vars(args))
Now vars(). I see nothing wrong with it, but when I look into one of your 
func implementations
> def info(args): # Provides information of a number of feeds
> session = Session(args)
> if "all" in args["names"]:
> feeds = session.list_feeds()
> else:
> feeds = args["names"]
> for feed in feeds:
> pretty_print(session, feed)

I come to the conclusion that passing args directly could make your life 
easier:
def info(args): 
 """Provides information of a number of feeds"""
 session = Session(args)
 if "all" in args.names:
 feeds = session.list_feeds()
 else:
 feeds = args.names
 for feed in feeds:
 pretty_print(session, feed)
As far as I can see there is only one place where the key is not a constant, 
and you can rewrite that from 
> try:
> if args[value]:
> return args[value]
> except KeyError:
> pass

to
try:
 answer = getattr(args, value)
 if answer: 
 return answer
except AttributeError:
 pass


More information about the Python-list mailing list

AltStyle によって変換されたページ (->オリジナル) /