Python while循环问题
Infle是一个谱系: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
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
,但不会使用。看见