|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
1. 编写一个程序,比较用户输入的两个文件,如果不同,显示出所有不同处的行号与第一个不同字符的位置...
相关代码
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 迭代: for line1 in f1: 获取每一行。
#for each_line in file: 等同于"for each_line in list(file)", list()方法将文件的每一行转换成列表的一个元素, 那这样想: 利用for迭代文件 (file) 内容使得每行相当于list 列表中的一个元素,也就是相当于每一个eachline是列表中的一个元素。for each_line in file那这迭代的每一行,是不是有索引的???
这样理解可以吗,还是要如何理解,请各位大神指点下。
String 字符串本身就是数组,不需要再把它变成数组 list
For A in B: #让 A 去在 B 内部做一些事情
不要太在意名字,只是一个代号。当然,一开始用方便自己理解的文字作为代号,如 line1 >> each_line
那段代码是读第一个文件的第一行时,读第二个文件的第一行,次数+1,比对
|
|