Python进行区间取值案例讲解
作者:dandanforgetlove 发布时间:2021-10-23 15:17:34
标签: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
来源:https://blog.csdn.net/dandanforgetlove/article/details/119246127
0
投稿
猜你喜欢
- 1、在全局settings文件中配置```MEDIA_URL = '/media/'MEDIA_ROOT = os.path
- 先由exp把数据卸出到文件系统, 产生一个.dmp文件, 然后必要时再由imp将数据装入数据库. 对于一般中小型数据库来说, 全数据库的ex
- 相信很多人像我一样在学习python,pandas过程中对数据的选取和修改有很大的困惑(也许是深受Matlab)的影响。。。到今天终于完全搞
- 进程与线程的历史我们都知道计算机是由硬件和软件组成的。硬件中的CPU是计算机的核心,它承担计算机的所有任务。 操作系统是运行在硬件之上的软件
- asp之日期和时间函数示例可以使用日期和时间函数来得到各种格式的日期和时间函数语法说明示例NowNow()取得系统当前的日期和
- 一定要注重代码规范,按照平时的代码管理,可以将Python代码规范检测分为两种:静态本地检测:可以借助静态检查工具,比如:Flake8,Py
- 首先上一段程序:import numpy as nplist_a = list(range(10))print("list_a:
- 下面基础的解释一下这错误: 1:本质上的错误: object a;//a是Null对象 protected void Page_Load(o
- 自己做了一个asp页面,用了一个td来显示留言本的最新消息;但是却无法控制其排版问题,因为该td的width确定,但是数据库中的文字却是未知
- 这几天有一台MySQL数据库服务器出现了频繁的掉线情况,通过排查,并没有排查出哪个网站被攻击,百思不得其解中的时候,群里有个朋友说是因为微软
- 这篇文章主要介绍了IOS苹果AppStore内购付款的服务器端php验证方法(使用thinkphp)。AppStore内购在app中支付的过
- 在一行内声明CSS,对比下面两个:h2 {font-size:18px; border:1px solid&n
- 在前后端分离是大趋势的背景下,前端获取数据都是通过调用后台的接口来获取数据微服务的应用越来越多。Django是Python进行web应用开发
- PHP mysqli_thread_id() 函数返回当前连接的线程 ID,然后杀死连接:<?php// 假定数据库用户名:root,
- 在程序调试中,有时候需要知道有多少Session变量在使用,她们的值如何?由于Session对象提供一个称为Contents的集合(Coll
- <% set conn=server.createobject("adodb.connect
- 本文实例讲述了Python实现返回数组中第i小元素的方法。分享给大家供大家参考,具体如下:#! /usr/bin/env python#co
- 1.获取所有数据库名: SELECT Name FROM Master..SysDatabases ORDER BY Name2.获取所有表
- 原理中文分词,即 Chinese Word Segmentation,即将一个汉字序列进行切分,得到一个个单独的词。表面上看,分词其实就是那
- 函数内省(function introspection)除了__doc__属性, 函数对象还有很多属性,对于下面的函数,可以使用dir()查