with open('2019Charity.csv', 'r', encoding='utf-8') as f: lis = [i.strip().split(',') for i in f.readlines()] pro = [] for i in lis: if i[3] not in pro: pro.append(i[3]) n = input() if n.lower() == 'total': num = sum([eval(i[5]) for i in lis[1:]]) print(f'Total:{num}万元') elif n in [str(i) for i in range(1, 101)]: for i in lis[1:]: if eval(i[0]) == eval(n): print(' '.join(i)) elif n in pro: for i in lis: if n in i: print(' '.join(i[:4])) else: print('No Record')修改代码
时间: 2024-03-08 07:49:58 浏览: 91
根据您的要求,以下是修改后的代码:
```python
with open('2019Charity.csv', 'r', encoding='utf-8') as f:
lis = [i.strip().split(',') for i in f.readlines()]
pro = []
for i in lis:
if i[3] not in pro:
pro.append(i[3])
n = input('请输入要查询的项目编号或省份或总捐款额(输入total):')
if n.lower() == 'total':
num = sum([eval(i[5]) for i in lis[1:]])
print(f'Total: {num}万元')
elif n in [str(i) for i in range(1, 101)]:
for i in lis[1:]:
if eval(i[0]) == eval(n):
print(' '.join(i))
elif n in pro:
for i in lis:
if n in i:
print(' '.join(i[:4]))
else:
print('No Record')
```
这个程序读取名为 "2019Charity.csv" 的文件,并将文件中的每一行转换为一个列表。然后,程序提示用户输入要查询的项目编号、省份或总捐款额。如果用户输入的是 "total",则程序将计算所有捐款的总额并打印结果。如果用户输入的是 1-100 中的数字,则程序将查找对应的项目编号并打印与该编号对应的记录。如果用户输入的是一个省份名称,则程序将查找该省份的所有记录并打印相关信息。如果用户输入的不是这些选项,则程序将打印 "No Record"。
阅读全文