要编辑CSV文件中的查询,您可以使用Python中的csv模块。下面是一个示例代码,演示如何使用csv模块来查询和编辑CSV文件。
首先,让我们假设有一个名为data.csv的CSV文件,它的内容如下:
name,age,city
John,25,New York
Emma,30,Los Angeles
现在,我们将演示如何查询和编辑这个CSV文件。
import csv
# 查询CSV文件
def query_csv(file_name, query):
with open(file_name, 'r') as file:
csv_reader = csv.DictReader(file)
for row in csv_reader:
if query(row):
print(row)
# 编辑CSV文件
def edit_csv(file_name, edit_query, edit_function):
# 创建临时文件
temp_file = 'temp.csv'
with open(file_name, 'r') as file, open(temp_file, 'w', newline='') as temp:
csv_reader = csv.DictReader(file)
fieldnames = csv_reader.fieldnames
csv_writer = csv.DictWriter(temp, fieldnames=fieldnames)
csv_writer.writeheader()
for row in csv_reader:
if edit_query(row):
edited_row = edit_function(row)
csv_writer.writerow(edited_row)
else:
csv_writer.writerow(row)
# 用临时文件替换原文件
import shutil
shutil.move(temp_file, file_name)
# 示例查询函数
def query_function(row):
return row['age'] == '30' and row['city'] == 'Los Angeles'
# 示例编辑函数
def edit_function(row):
row['age'] = '31'
return row
# 查询CSV文件
query_csv('data.csv', query_function)
# 编辑CSV文件
edit_csv('data.csv', query_function, edit_function)
在上面的代码中,query_csv
函数用于查询CSV文件,它接受两个参数:文件名和查询函数。查询函数接受一行作为输入,根据需要返回True或False。在示例中,query_function
函数用于查询年龄为30且城市为洛杉矶的行。
edit_csv
函数用于编辑CSV文件,它接受三个参数:文件名、编辑查询函数和编辑函数。编辑查询函数用于确定哪些行应该被编辑,编辑函数用于对行进行实际的编辑。在示例中,edit_function
函数将年龄更改为31。
最后,我们调用query_csv
函数来查询CSV文件,并调用edit_csv
函数来编辑CSV文件。
下一篇:编辑CSV文件中的错误行