零基础python第29讲,for line1 in file 是一行一行遍历文件的吗?
题目要求:编写一个程序,比较用户输入的两个文件,如果不同,显示出所有不同处的行号与第一个不同字符的位置。
小甲鱼代码:
def file_compare(file1, file2):
f1 = open(file1)
f2 = open(file2)
count = 0 # 统计行数
differ = [] # 统计不一样的数量
for line1 in f1:
line2 = f2.readline()
count += 1
if line1 != line2:
differ.append(count)
f1.close()
f2.close()
return differ
file1 = input('请输入需要比较的头一个文件名:')
file2 = input('请输入需要比较的另一个文件名:')
differ = file_compare(file1, file2)
if len(differ) == 0:
print('两个文件完全一样!')
else:
print('两个文件共有【%d】处不同:' % len(differ))
for each in differ:
print('第 %d 行不一样' % each)
请教:
for line1 in f1 的循环遍历是一行一行遍历的还是一个字符一个字符遍历的?我猜想是前者,但是网上找不到相应教程,请各位高手帮忙指教。谢谢! 是的 是的 for line1 in f1,每一次迭代相当于readline一次,作用是从当前字符读取到换行符\回车符,然后将指针指向下一行,如果是文件尾,迭代退出。 for line1 in f1 是一行一行遍历文件,而 for xxx in 字符串 是一个字符一个字符地遍历,一定要分清楚。 明白了,谢谢各位{:5_95:}
页:
[1]