下面是一个示例代码,用于读取一个文件中的行并计算它们的和,同时跳过重复的行:
def calculate_sum(filename):
unique_lines = set() # 用于保存不重复的行
total_sum = 0 # 用于保存求和结果
# 逐行读取文件内容
with open(filename, 'r') as file:
for line in file:
line = line.strip() # 去除行末尾的换行符和空白字符
# 跳过重复的行
if line in unique_lines:
continue
# 将行添加到集合中
unique_lines.add(line)
# 将行的数字部分转换为整数并累加到总和
try:
num = int(line)
total_sum += num
except ValueError:
pass # 忽略无法转换为整数的行
return total_sum
# 使用示例
filename = 'input.txt'
result = calculate_sum(filename)
print(f'The sum of unique lines in "{filename}" is: {result}')
在上述示例代码中,我们首先创建一个空集合 unique_lines
用于保存不重复的行。然后,我们逐行读取文件内容,将每行首先去除末尾的换行符和空白字符,并判断该行是否已经在集合 unique_lines
中。如果是重复的行,则跳过该行继续处理下一行。如果是不重复的行,则将该行添加到集合中,并将行的数字部分转换为整数并累加到总和 total_sum
中。最后,返回总和作为结果。
请注意,在示例代码中,我们假设输入文件中的每一行都是一个有效的数字。如果文件中存在无法转换为整数的行,我们使用 try-except
块来捕获 ValueError
异常,并忽略该行。如果需要处理其他类型的行,可以根据实际情况进行相应的修改。