Python小技巧!如何简化大量的 if…elif…else 代码?

开发 后端
今天在 Github 阅读EdgeDB[1]的代码,发现它在处理大量if...elif...else判断的时候,使用了一个非常巧妙的装饰器。我们来看看这个方法具体是什么样的。

 [[439061]]

今天在 Github 阅读EdgeDB[1]的代码,发现它在处理大量if...elif...else判断的时候,使用了一个非常巧妙的装饰器。我们来看看这个方法具体是什么样的。

正好今天是双十一,假设我们要做一个功能,根据用户的等级判断他可以获得的折扣。常规的if ... elif...写法是这样的: 

def get_discount(level):  
    if level == 1:  
        "大量计算代码"  
        discount = 0.1  
    elif level == 2:  
        "大量计算代码"  
        discount = 0.2  
    elif level == 3:  
        discount = 0.3  
    elif level == 4:  
        discount = 0.4  
    elif level == 5:  
        discount = 0.5  
    elif level == 6:  
        discount = 3 + 2 - 5 * 0.1  
    else:  
         return '等级错误'  
    return discount 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.

大家都知道,这样大量的if ... elif...代码非常难看,也很难维护。并且每个 if 的内部有很多代码。这个函数就会被拉得非常长。

有一些同学知道,可以使用字典来改写这个太长的 if 判断: 

def parse_level_1():  
    "大量计算代码"  
    discount = 0.1  
    return discount  
def parse_level_2():  
    "大量计算代码"  
    discount = 0.2  
    return discount  
def parse_level_3():  
    "大量计算代码"  
    discount = 0.3  
    return discount  
def parse_level_4():  
    "大量计算代码"  
    discount = 0.4  
    return discount  
def parse_level_5():  
    "大量计算代码"  
    discount = 0.5  
    return discount  
def parse_level_6():  
    "大量计算代码"  
    discount = 3 + 2 - 5 * 0.1  
    return discount  
discount_map = {  
 1: parse_level_1,  
  2: parse_level_2,  
  3: parse_level_3,  
  4: parse_level_4,  
  5: parse_level_5,  
  6: parse_level_6,  
 
discount = discount_map.get(level, '等级错误') 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.

但今天我学到的这个方法,比用字典更简单。我们先来看它的效果: 

@value_dispatch  
def get_discount(level):  
    return '等级错误'  
@get_discount.register(1)  
def parse_level_1(level):  
    "大量计算代码"  
    discount = 0.1  
    return discount  
@get_discount.register(2)  
def parse_level_2(level):  
    "大量计算代码"  
    discount = 0.2  
    return discount  
@get_discount.register(3)  
def parse_level_3(level):  
    "大量计算代码"  
    discount = 0.3  
    return discount  
@get_discount.register(4)  
def parse_level_4(level):  
    "大量计算代码"  
    discount = 0.4  
    return discount  
@get_discount.register(5)  
def parse_level_5(level):  
    "大量计算代码"  
    discount = 0.5  
    return discount  
@get_discount.register(6)  
def parse_level_1(level):  
    "大量计算代码"  
    discount = 3 + 2 - 5 * 0.1  
    return discount  
discount = get_discount(3)  
print(f'等级3的用户,获得的折扣是:{discount}') 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.

运行效果如下图所示:

这样写,比用字典的方式更直观,比直接用if ... elif...更简洁。

那么,这个装饰器value_dispatch是怎么实现的呢?密码就藏在这个开源项目EdgeDB的源代码[2]中,核心代码只有20多行:

并且,还能够实现或查询。例如用户等级为2或者3的时候,折扣都是0.2,那么代码可以写成: 

@get_discount.register(2)  
@get_discount.register(3)  
def parse_level_2(level):  
    "大量计算代码"  
    discount = 0.2  
    return discount 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.

运行效果如下图所示:

它这个代码目前只能实现相等的查询。但其实只要对这个代码稍作修改,我们就能实现大于、小于、大于等于、小于等于、不等于、in等等判断。如果大家有兴趣的话,请在文章下面留言,我们明天就来说说怎么对这个代码进行改造,实现更多的逻辑判断。 

 

责任编辑:庞桂玉 来源: 菜鸟学Python
相关推荐

2021-11-12 05:00:43

装饰器代码功能

2022-11-04 11:18:16

代码优化可读性

2021-06-05 05:11:52

代码状态机逻辑

2022-07-11 08:16:55

策略模式if-else

2024-04-26 08:58:54

if-else代码JavaSpring

2023-09-14 12:58:17

Python开发

2009-09-07 22:29:04

LINQ组合查询

2024-01-08 17:09:07

Python解释器CPython

2022-01-06 22:31:21

Python技巧代码

2021-12-19 22:36:42

Python代码开发

2024-05-16 12:03:54

Python代码开发

2023-12-06 13:43:00

python代码

2018-11-28 12:30:58

Python命令行编程语言

2022-11-24 10:34:05

CSS前端

2015-09-15 08:30:23

Android代码优化

2022-03-10 08:01:06

CSS技巧选择器

2020-09-26 21:50:26

JavaScript代码开发

2020-05-25 15:17:11

Python安装的库方法

2020-05-07 17:03:49

Python编码开发

2016-08-05 15:33:26

Python编程异常
点赞
收藏

51CTO技术栈公众号