Python进行区间取值案例讲解


Posted in Python onAugust 02, 2021

需求背景:

进行分值计算。如下图,如果只是一两个还好说,写写判断,但是如果有几十个,几百个,会不会惨不忍睹。而且,下面的还是三种情况。

例如:

Python进行区间取值案例讲解

Python进行区间取值案例讲解

解决:

# 根据值、比较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

到此这篇关于Python进行区间取值案例讲解的文章就介绍到这了,更多相关Python进行区间取值内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python输出PowerPoint(ppt)文件中全部文字信息的方法
Apr 28 Python
Python pickle模块用法实例分析
May 27 Python
python中使用序列的方法
Aug 03 Python
python中安装Scrapy模块依赖包汇总
Jul 02 Python
python 读取视频,处理后,实时计算帧数fps的方法
Jul 10 Python
使用python对excle和json互相转换的示例
Oct 23 Python
PyQt5的安装配置过程,将ui文件转为py文件后显示窗口的实例
Jun 19 Python
python多任务之协程的使用详解
Aug 26 Python
使用python采集Excel表中某一格数据
May 14 Python
基于python计算滚动方差(标准差)talib和pd.rolling函数差异详解
Jun 08 Python
Python保存并浏览用户的历史记录
Apr 29 Python
Python编写车票订购系统 Python实现快递收费系统
Aug 14 Python
Python获取江苏疫情实时数据及爬虫分析
Django对接elasticsearch实现全文检索的示例代码
Aug 02 #Python
浅谈Python3中datetime不同时区转换介绍与踩坑
Aug 02 #Python
python数字转对应中文的方法总结
Aug 02 #Python
Python List remove()实例用法详解
Aug 02 #Python
Python中基础数据类型 set集合知识点总结
Aug 02 #Python
python unittest单元测试的步骤分析
Aug 02 #Python
You might like
PHP脚本的10个技巧(1)
2006/10/09 PHP
php输出图像的方法实例分析
2017/02/16 PHP
PHP如何通过表单直接提交大文件详解
2019/01/08 PHP
Jquery在IE7下无法使用 $.ajax解决方法
2009/11/11 Javascript
js 变量类型转换常用函数与代码[比较全]
2009/12/01 Javascript
浅谈javascript中的call、apply、bind
2016/03/06 Javascript
用JS动态改变表单form里的action值属性的两种方法
2016/05/25 Javascript
浅谈javascript:两种注释,声明变量,定义函数
2016/10/05 Javascript
Javascript 获取鼠标当前的位置实现方法
2016/10/27 Javascript
浅谈vue-cli加载不到dev-server.js的解决办法
2017/11/24 Javascript
详解vue2.0 不同屏幕适配及px与rem转换问题
2018/02/23 Javascript
vue+vant使用图片预览功能ImagePreview的问题解决
2020/04/10 Javascript
jdk1.8+vue elementui实现多级菜单功能
2020/09/24 Javascript
OpenLayers3实现地图鹰眼以及地图比例尺的添加
2020/09/25 Javascript
用python实现批量重命名文件的代码
2012/05/25 Python
python实现批量获取指定文件夹下的所有文件的厂商信息
2014/09/28 Python
python实现根据月份和日期得到星座的方法
2015/03/27 Python
Python实时获取cmd的输出
2015/12/13 Python
python实现对任意大小图片均匀切割的示例
2018/12/05 Python
Python中remove漏删和索引越界问题的解决
2020/03/18 Python
HTML5安全介绍之内容安全策略(CSP)简介
2012/07/10 HTML / CSS
HTML5中如何显示视频呢 HTML5视频播放demo
2013/06/08 HTML / CSS
HTML5 canvas基本绘图之绘制曲线
2016/06/27 HTML / CSS
super关键字的用法
2012/04/10 面试题
什么是表空间(tablespace)和系统表空间(System tablespace)
2013/02/25 面试题
应聘自荐书
2013/10/08 职场文书
工厂厂长的职责
2013/12/12 职场文书
领导视察欢迎词
2014/01/15 职场文书
爱护公共设施演讲稿
2014/09/13 职场文书
工程催款通知书
2015/04/17 职场文书
2016关于读书活动的心得体会
2016/01/14 职场文书
解决Navicat for Mysql连接报错1251的问题(连接失败)
2021/05/27 MySQL
Mybatis-plus在项目中的简单应用
2021/07/01 Java/Android
HTML基本元素标签介绍
2022/02/28 HTML / CSS
Tomcat项目启动失败的原因和解决办法
2022/04/20 Servers
Python何绘制带有背景色块的折线图
2022/04/23 Python