如何在python列表中附加字段值并忽略None值

时间:2019-03-28 16:10:51

标签: python python-3.x odoo odoo-11

我需要计算某些字段的平均值,而忽略所有值,这就是我可以做的事情

@api.multi
def update_bar(self):
    list=[self.item.pro, self.drc.pro, self.dsc.pro, self.org.pro, 
          self.car.pro, self.model.pro, self.year.pro]
    for rec in list:
        if rec:
            self.new_list = list.append(rec)
    print(self.new_list)
    pass

3 个答案:

答案 0 :(得分:2)

我会使用列表理解

FOR /F

答案 1 :(得分:0)

您可以从列表中过滤None值,然后进一步进行常规的求和/平均值计算。让我们像下面一样过滤掉None-

list=[self.item.pro, self.drc.pro, self.dsc.pro, self.org.pro, 
          self.car.pro, self.model.pro, self.year.pro]
list_without_none = [x for x in list if x is not None]

要计算平均值 ,请假设您具有以下值。

# Python program to get average of a list 
def Average(lst): 
    return sum(lst) / len(lst) 

# Driver Code 
list_without_none = [15, 9, 55, 41, 35, 20, 62, 49] 
average = Average(list_without_none) 
print(average)

查看更多 DEMO's

答案 2 :(得分:0)

您始终可以使用过滤器功能。下面的例子。结果,您将获得第一个列表,但过滤掉所有内容。

new_list = filter(lambda x: x is not None, list)
mean = sum(new_list)/len(new_list)