我在python中有一个相当长的列表,我希望将它的一部分返回到基于3个百分比的单个较短列表中。如果第一个百分比为30%,则需要返回前30%的值,如果第三个百分比为50%,则需要返回我的长列表的后半部分值。
这是我到目前为止,它有舍入问题,是一个丑陋的解决方案
class OM():
def __init__(self,name):
self.name = name
self.total = 120
self.a = 21
self.b = 34
self.c = 65
def hRange(self,action):
if self.total > 0:
a_perc = int(self.a / float(self.total) *169)
b_perc = int(self.b / float(self.total) *169)
c_perc = int(self.c / float(self.total) *169)
if action=='a': return lst[:aperc]
elif action=='b': return lst[a_perc:a_perc+b_perc]
elif action=='c': return lst[-c_perc:]
else:
raise Exception
我意识到这根本没有很好的编码,(硬编码长度为169,没有捕捉不同的动作等等)我只想帮助解释我想要做的事情。
在我的实际实现中,值total,a,b,c将初始化为0,另一种方法会更新它们,因为它们只是计数器。我只是将它们设置为一些随机值,因此代码返回百分比。
如果有人能就如何更好地做到这一点给我任何建议,我将非常感激。
答案 0 :(得分:2)
如果我理解正确,你想保留三个列表,基于开头和结尾的某个百分比加上“介于两者之间”:
def split_list(mylist, a, b):
l = len(mylist)
return ( mylist[:int(a*l/100)],
mylist[int(a*l/100):-int(b*l/100)],
mylist[-int(b*l/100):] )
其中a和b是百分比(从0到100给出)。它与您的实现几乎相同,但您只需要使用两个百分比(如果中间列表是两端被修剪掉时的剩余部分)。我将把它留在你的代码中......
答案 1 :(得分:1)
得到了一般解决方案...我相信这应该处理所有情况:
def split_list(mylist, *args):
ilist = map(lambda p : int(p * len(mylist) / 100.0), args) + [len(mylist)]
return reduce(lambda l, v : [l[0] + [mylist[l[1]:v]], v], ilist, [[],0])[0]
该功能采用列表和百分比分割点列表(按顺序),并根据需要返回列表。处理分割百分比多于列表中项目的情况。