用python计算平均值

2024-06-01 10:16:01 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在编写一个程序,该程序提示输入文件名,然后打开该文件并读取该文件,查找表单中的行:

X-DSPAM-置信度:0.8475

我想对这些行进行计数,从每行中提取浮点值,并计算这些值的平均值。我能请你帮忙吗。我刚开始编程,所以我需要一些非常简单的东西。这是我已经写的代码。你知道吗

fname = raw_input("Enter file name: ")
    if len(fname) == 0:
        fname = 'mbox-short.txt'
    fh = open(fname,'r')
    count = 0
    total = 0
    #Average = total/num of lines
    for line in fh:
        if not line.startswith("X-DSPAM-Confidence:"): continue
        count = count+1
        print line

Tags: 文件程序表单if文件名countlinefname
3条回答

迭代文件(使用上下文管理器(“with”)自动处理关闭),查找这样的行(就像您所做的那样),然后按如下方式读取它们:

fname = raw_input("Enter file name:")
if not fname:
    fname = "mbox-short.txt"
scores = []
with open(fname) as f:
    for line in f:
        if not line.startswith("X-DSPAM-Confidence:"):
            continue
        _, score = line.split()
        scores.append(float(score))
print sum(scores)/len(scores)

或者更紧凑一点:

mean = lambda x: sum(x)/len(x)
with open(fname) as f:
    result = mean([float(l.split()[1]) if line.startswith("X-DSPAM-Confidence:") for l in f])

尝试:

total += float(line.split(' ')[1])

所以total / count给出了答案。你知道吗

像下面这样的程序应该能满足你的需要。如果您需要更改程序要查找的内容,只需更改PATTERN变量来描述您要匹配的内容。代码是为Python3.x编写的,但是如果需要的话,可以很容易地适应Python2.x。你知道吗

程序:

#! /usr/bin/env python3
import re
import statistics
import sys


PATTERN = r'X-DSPAM-Confidence:\s*(?P<float>[+-]?\d*\.\d+)'


def main(argv):
    """Calculate the average X-DSPAM-Confidence from a file."""
    filename = argv[1] if len(argv) > 1 else input('Filename: ')
    if filename in {'', 'default'}:
        filename = 'mbox-short.txt'
    print('Average:', statistics.mean(get_numbers(filename)))
    return 0


def get_numbers(filename):
    """Extract all X-DSPAM-Confidence values from the named file."""
    with open(filename) as file:
        for line in file:
            for match in re.finditer(PATTERN, line, re.IGNORECASE):
                yield float(match.groupdict()['float'])


if __name__ == '__main__':
    sys.exit(main(sys.argv))

如果需要,还可以用以下方式实现get_numbers生成器。你知道吗

备选方案:

def get_numbers(filename):
    """Extract all X-DSPAM-Confidence values from the named file."""
    with open(filename) as file:
        yield from (float(match.groupdict()['float'])
                    for line in file
                    for match in re.finditer(PATTERN, line, re.IGNORECASE))

相关问题 更多 >