Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]
Groups > comp.lang.python > #10545
| From | Peter Otten <__peter__@web.de> |
|---|---|
| Subject | Re: removing nested iffs |
| Date | 2011-07-29 22:42 +0200 |
| Organization | None |
| References | <CAAAhF4GeXr+vxNCcJeHm1LfvTciqzSTrp0f3onx020PJSGh4MA@mail.gmail.com> |
| Newsgroups | comp.lang.python |
| Message-ID | <mailman.1632.1311972191.1164.python-list@python.org> (permalink) |
Josh Benner wrote:
> I'm writing a function to create a string that gets longer iff an argument
> is defined. In there a more elegant way than nesting all those ifs?
>
> def format_rsync_src_string(args, server="RSYNC"):
> """ Format an rsync source directory string. """
> if args.server is None:
> raise CopyNightlyError("No rsync server provided.")
> src = "{0}::".format(args.server)
> if args.project not None:
> src += "{0}/".format(args.project)
> if args.version not None:
> src += "{0}/".format(args.version)
> if args.build not None:
> src += "Build {0}".format(args.build)
> return src
How about
def format_pairs(pairs):
for template, value in pairs:
if value is None:
break
yield template.format(value)
def format_rsync_src_string(args, server="RSYNC"):
""" Format an rsync source directory string. """
if args.server is None:
raise CopyNightlyError("No rsync server provided.")
return "".join(format_pairs([
("{0}::", args.server),
("{0}/", args.project),
("{0}/", args.version),
("Build {0}", args.build)]))
Back to comp.lang.python | Previous | Next | Find similar | Unroll thread
Re: removing nested iffs Peter Otten <__peter__@web.de> - 2011-07-29 22:42 +0200
csiph-web