Python while循环问题

Python while循环问题,python,file-io,while-loop,Python,File Io,While Loop,Infle是一个谱系: holla 1755 ronaj 1781 asdflæj 1803 axle 1823 einar 1855 baelj 1881 æljlas 1903 jobbi 1923 gurri 1955 kolli 1981 Rounaj 2004 我想打印出每一代人的时间从infle和在最后我想要的平均值。在这里,我认为我的问题是当填充结束时,line2超出范围: def main(): infile = open('inf

Infle是一个谱系:

holla   1755
ronaj   1781
asdflæj 1803
axle    1823
einar   1855
baelj   1881
æljlas  1903
jobbi   1923
gurri   1955
kolli   1981
Rounaj  2004
我想打印出每一代人的时间从infle和在最后我想要的平均值。在这里,我认为我的问题是当填充结束时,
line2
超出范围:

def main():
    infile = open('infile.txt', 'r')
    line = infile.readline()
    tmpstr = line.split('\t')
    age=[]
    while line !='':
        line2 = infile.readline()
        tmpstr2 = line2.split('\t')
        age.append(int(tmpstr2[1]) - int(tmpstr[1]))
        print age
        tmpstr = tmpstr2
    infile.close()
    print sum(age)*1./len(age)
main()
因此,我决定将所有信息读取到列表中,但
tmpstr
不会改变此处的值:

def main():
    infile = open('infile.txt', 'r')
    line = infile.readline()
    age=[]
    while line !='':
        tmpstr = line.split('\t')
        age.append(tmpstr[1])
        print age
    infile.close()
    print sum(age)*1./len(age)
main()
为什么?这两个脚本有什么问题?为什么我要写两次
main()
? 有没有办法解决这两个问题

Thanx所有人,事情就是这样结束的:

   def main():
        with open('infile.txt', 'r') as input:
            ages = []
            for line in input:
                data = line.split()
                age = int(data[1])
                ages.append(age)
            gentime = []
            for i in xrange(len(ages)-1):
                print ages[i+1] - ages[i]
                gentime.append(ages[i+1] - ages[i]) 
            print 'average gentime is', sum(gentime)*1./len(gentime)
    main()

您可以使用以下语句迭代文件的全部内容:

for line in infile:
    # Perform the rest of your steps here

您不想使用while循环,除非您有某种计数器来切换索引位置(即,您使用了
infle.readlines()
,并且希望使用while循环)。

在第二种情况下,您的代码只读取文件中的一行

简单点,比如:

age = []
with open('data.txt', 'rt') as f:
   for line in f:
      vals = line.split('\t')
      age.append(int(vals[1]))

print sum(age) / float(len(age))
产生

1878.54545455
试试这个:

def main():
    with open('infile.txt', 'r') as input:
        ages, n = 0, 0
        for line in input:
            age = int(line.split()[1])
            ages += age
            n += 1
            print age
        print 'average:', float(ages) / n
一些评论:

  • 您不需要使用列表来累加数字,几个局部变量就足够了
  • 在这种情况下,最好使用不带参数的
    split()
    ,这样,当名称与前面的数字之间用空格或制表符分隔时,就可以正确地处理输入
  • 使用
    with
    语法打开文件并确保随后关闭文件也是一个好主意

关于问题的最后一部分,“为什么我要写main()两次?”这是因为第一次定义
main
函数,第二次调用它。

您可以尝试以下方法:

if __name__ == "__main__":
    file = open("infile.txt", "r")
    lines = file.readlines()
    gens = [int(x.split('\t')[1]) for line in lines]
    avg = sum(gens)/len(gens)
第一行是python进入程序的本机入口。它相当于C的“int main()”

接下来,如果您将文件中的所有行读取到列表中,那么可能最容易设置列表理解


第4行遍历文件行,在选项卡上拆分它们,并仅从新拆分的列表中检索第2项(在索引1处)。

这两个脚本的问题在于
while
循环是无限的。条件
行!=''永远不会为false

您可以修复此问题,但最好使用Python习惯用法:

lastyear = None
ages = []
for line in infile:
    _name, year = line.split('\t')
    year = int(year)
    if lastyear:
        ages.append(year - lastyear)
    lastyear = year
print float(sum(ages))/len(ages)

我建议这样做。@Martin:codereview.SE不支持坏代码。@NiklasBaumstark:好的,说得好。我以前没有这样想过。也许你更想要
float(ages)/n
为什么在_name中的第一个字符是下划线?这只是给读者一个提示,元组解包需要
_name
,但不会使用。看见