Python进行区间取值案例讲解
作者:dandanforgetlove 时间:2021-10-23 15:17:34
需求背景:
进行分值计算。如下图,如果只是一两个还好说,写写判断,但是如果有几十个,几百个,会不会惨不忍睹。而且,下面的还是三种情况。
例如:
解决:
# 根据值、比较list, 值list,返回区间值, other_value 即不在的情况
def get_value_by_between(self, compare_value, compare_list, value_list, other_value, type="compare", left=False,
right=True):
try:
if compare_value is None or compare_value == '':
return other_value
if len(compare_list) != len(value_list):
raise Exception("区间对比两个list长度不一致")
# # 如果比较的值和其它情况值一致,说明是其它情况
# if compare_value == other_value:
# return other_value
# 左边开区间
if compare_list[0] == -9999999 and compare_list[1] >= compare_value:
return value_list[0]
# 右边开区间
if right is True and compare_value > compare_list[len(compare_list) - 1]:
return value_list[len(compare_list) - 1]
# 左边开区间
# if left is True and compare_value <= compare_list[0]:
# return compare_value[0]
for ind, this_val in enumerate(compare_list):
# 如果是最后一个,则返回最后一个值
if compare_value > compare_list[len(compare_list) - 1]:
return value_list[len(compare_list) - 1]
# 返回默认的
elif (ind + 1) == len(compare_list):
return other_value
# 下一个,如果大于compare_list长度减1 ,就返回最后一个
next_val = compare_list[ind if ind >= len(compare_list) else ind + 1]
# 第一个的话就是 大于等于,小于下一个
if ind == 0 and compare_value >= this_val and compare_value <= next_val:
return value_list[ind]
# 大于左边,小于等于右边
elif this_val < compare_value and compare_value <= next_val:
return value_list[ind]
except:
log.error("根据区间计算分数异常", traceback.format_exc())
return other_value
# 数字型
def get_val_by_list(self, compare_value, compare_list, val_list, other_value):
try:
if compare_value is None:
return other_value
for ind, li in enumerate(compare_list):
if len(li) == 1 and compare_value == li[0]:
return val_list[ind]
# 最后一个
elif len(li) == 1 and (ind + 1) == len(compare_list) and compare_value >= li[0]:
return val_list[ind]
elif len(li) == 2 and compare_value >= li[0] and compare_value <= li[1]:
return val_list[ind]
except:
log.error(" get_val_by_list 异常", traceback.format_exc())
return other_value
TEST
# creditTime 即值
self.get_val_by_list(creditTime, [[0],[1],[2],[3]], [20, 10, 0, -100],
other_value=0)
self.get_value_by_between(taxCreditRating, [0, 60, 70, 80, 90],[-200, 0, 10, 20, 30], other_value=0)
如果是图2,即第三种情况,则需要多加一个0,和对应的值。
self.get_value_by_between(taxAmt12m, [0,0, 1000, 15000, 50000, 200000],[-50, -50, 0, 0, 5, 10], -0)
如果是负无穷大,则使用-999999
来源:https://blog.csdn.net/dandanforgetlove/article/details/119246127
标签:python,区间
0
投稿
猜你喜欢
怎么样用xmlhttp读取远程xml的数据
2008-10-11 13:52:00
python 多维高斯分布数据生成方式
2022-12-20 20:29:40
asp如何将产生的密码记录并发送给用户?
2009-11-26 20:50:00
python 内置模块详解
2023-09-08 00:55:55
自定义百度分享的分享按钮
2024-04-19 09:45:44
深度学习开源框架基础算法之傅立叶变换的概要介绍
2022-05-25 22:18:47
SQLSERVER 本地查询更新操作远程数据库的代码
2023-07-23 21:58:55
MySql创建分区的方法实例
2024-01-23 22:17:40
使用sql语句创建和删除约束示例代码
2024-01-15 21:55:51
Golang正整数指定规则排序算法问题分析
2023-07-12 09:12:03
vue实现表单验证功能
2024-06-05 10:03:59
SpringBoot图文并茂详解如何引入mybatis与连接Mysql数据库
2024-01-25 15:07:32
MySQL复制表结构和内容到另一张表中的SQL语句
2024-01-20 17:20:59
vue3中的透传attributes教程示例详解
2024-05-05 09:22:34
ASP中使用Form和QueryString集合
2007-09-14 10:43:00
pandas创建DataFrame的7种方法小结
2022-01-11 19:26:18
mysql 8.0.15 winx64解压版图文安装教程
2024-01-16 08:22:32
IE6下图片下方有空隙的解决方法
2008-08-01 18:02:00
使用setup.py安装python包和卸载python包的方法
2023-01-31 02:20:47
简约的实现——服装网站设计
2009-03-06 12:43:00