首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >避免Python中嵌套的if else语句梯形图

避免Python中嵌套的if else语句梯形图
EN

Stack Overflow用户
提问于 2018-07-08 05:41:06
回答 2查看 3.9K关注 0票数 1

当你不知道如何准确地描述它时,很难找到这个问题的答案……

要处理一组相当深的(但固定的)嵌套测试,您希望按顺序运行这些测试,但在第一个测试获得成功结果后立即终止,最常用的方法是什么?

而不是以下内容

选项1: (导致过多的缩进)

代码语言:javascript
复制
def make_decision():

    results = ... some code or function that returns a list or None
    if results:
        decision = random.choice(results)
    else:
        results = ... other code or function
        if results:
            decision = random.choice(results)
        else:
            results = ... other code or function
            if results:
                decision = random.choice(results)
            else:
                results = ... other code or function
                if results:
                    decision = random.choice(results)

      ...etc.

                                else:
                                    decision = None

    print(decision)

    return decision

选项2

另一种选择是提前从函数返回,但我不确定有这么多返回分散在各处是不是一种好的做法,在这种情况下,我更喜欢在返回之前做最后一件事(例如print(decision)):

代码语言:javascript
复制
def make_decision():

    results = ... some code or function that returns a list or None
    if results:
        return random.choice(results)

    results = ... other code or function
    if results:
        return random.choice(results)

    results = ... other code or function
    if results:
        return random.choice(results)

    ...etc.

    else:
        decision = None

    return decision

选项3

最后,我可以使每个测试都有一个单独的函数as described here,并迭代地调用它们,前提是每个测试函数都有相同的参数集。

代码语言:javascript
复制
def test1(args):
    ...

def test2(args):
    ...

def test3(args):
    ...

def make_decision():

    decision = None
    for test in [test1, test2, test3, ...]:
        results = test(args)
        if results:
            decision = random.choice(results)
            break

    print(decision)

    return decision

这看起来是最好的,但我并不打算为每个测试创建一个函数,有些测试可以使用相同的函数,但使用不同的参数,有些只是一行代码,而其他的则是多行代码。那么,在开始循环之前,我是否必须构建一个函数和参数列表?或者创建一个partial函数列表?

欢迎任何更好的建议(在我继续上面的选项3之前)

更新2018-07-21:

A未来的潜在选项

在我努力解决这个问题时,我并不知道,PEP 572被批准了( van Rossum先生因此辞职)。如果实施此PEP,我认为以下解决方案也是可能的:

代码语言:javascript
复制
def make_decision():

    if (results := ... some code or function) is not None:
        decision = random.choice(results)
    elif (results := ... some code or function) is not None:
        decision = random.choice(results)

    ...etc.

    else:
        decision = None

    return decision
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-07-08 06:10:45

对不起,这是显而易见的,现在再看看它:

代码语言:javascript
复制
def make_decision():

    results = ... some code or function that returns a list or None

    if results is None:
        results = ... other code or function

    if results is None:
        results = ... other code or function

    ...etc.

    if results is None:
        decision = None
    else:
        decision = random.choice(results)
    print(decision)

    return decision
票数 -2
EN

Stack Overflow用户

发布于 2018-07-08 05:58:46

你可以选择任何选项,这完全取决于你的喜好。在选项2中,我不认为有很多return是个坏主意,因为它们包含在条件代码中。只有当该条件为True时,才会执行它们。

在选项1中,您可以决定切换到elif results:,而不是:

代码语言:javascript
复制
if results:
        # some code
    else:
        if results:
               # some code

在您的代码中,看起来像是在检查相同的results,看起来只有一个if块会执行。你应该检查一些值,例如if results == something

最后,选项3看起来更简洁。最后,选一个你觉得最舒服的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51227137

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档