初学 python 之处理文件中的数据

瞎学学呗

img

这篇文件写的是关于处理文件中的数据,比如现在拿到一份文档,里面有某个班级里所有学生的平时作业成绩。因为每个人交作业的次数不一样,所以成绩的数目也不同,没交作业的时候就没有分。

现在需要统计每个学生的平时作业总得分。

首先准备一个文档,里面的数据如下:
刘备 23 35 44 47 51
关羽 60 77 68
张飞 97 99 89 91
诸葛亮 100

首先,要达到我们的目标需要如下几步:
1.先把文件读进来
2.取得文件中的数据
3.对每一条数据进行处理,按照空格,把姓名、每次的成绩分割开
4.把每个学生的几次成绩合并,并保存起来
5.得到一个学生的总成绩后,把它添加到一个 list 中
6.最后,全部成绩处理完毕后,把results中的内容保存至文件

下面来看具体的操作步骤:

1.先把文件读进来:

1
f = open('C:/Users/xxxx/Desktop/data.txt')

2.取得文件中的数据。因为每一行都是一条学生成绩的记录,所以用
readlines,把每一行分开,便于之后的数据处理:

1
2
lines = f.readlines()
f.close()

提示:在程序中,经常使用 print 来查看数据的中间状态,可以便于你理解程序的运行。比如这里你可以 print lines,看一下内容被存成了什么格式。

3.对每一条数据进行处理。按照空格,把姓名、每次的成绩分割开:

1
2
for line in lines:
data = line.split()

接下来的4、5两个步骤都是针对一条数据的处理,所以都是在 for 循环的内部。

4.整个程序最核心的部分到了。如何把一个学生的几次成绩合并,并保存起来呢?我的做法是:对于每一条数据,都新建一个字符串,把学生的名字和算好的总成绩保存进去。最后再把这些字符串一起保存到文件中:

1
2
3
4
sum = 0
for score in data[1:]:
sum += int(score)
result = '%s\t: %d\n' % (data[0], sum)

这里几个要注意的点:
对于每一行分割的数据,data[0] 是姓名,data[1:] 是所有成绩组成的列表。
每次循环中,sum都要先清零。
score 是一个字符串,为了做计算,需要转成整数值 int。
result 中,我加了一个制表符 \t 和换行符
\n,让输出的结果更好看些。

5.得到一个学生的总成绩后,把它添加到一个 list 中。

1
results.append(result)

results 需要在循环之前初始化 results = []

6.最后,全部成绩处理完毕后,把 results 中的内容保存至文件。因为 results 是一个字符串组成的 list,这里我们直接用
writelines 方法:

1
2
3
output = open('C:/Users/xxxx/Desktop/data2.txt', 'w')
output.writelines(results)
outpus.close()

现在应该就是大功告成了。

来看一下具体的效果:

img

另外附上本人自学 python 的网址,很简单,适合新手入门,希望大家能够共同进步。