【Python与AI基础】Python编程基础:读写CSV文件
www.bilibili.com/video/BV1oe...
一、读取CSV并构建字典+列表数据
python
def read_csv(csvfile, has_column=True):
with open(csvfile) as f:
line_list = f.readlines()
if not has_column:
raise Exception('CSV文件必须要使用第一行作为列名')
# return None
key_list = line_list[0].strip().split(',')
list = []
for i in range(1, len(line_list)):
# 如果当前行以#开头,则直接绕过,到下一行进行处理
if line_list[i].startswith("#"):
continue
temp_list = line_list[i].strip().split(',')
dict = {}
for j in range(len(temp_list)):
dict[key_list[j]] = temp_list[j]
list.append(dict)
return list
二、使用csv内置模块读取
python
import csv
with open('./user-2.csv') as f:
# 读取并遍历每一行
csv_list = csv.reader(f)
for item in csv_list:
print(item)
# 读取并将结果强制转换成 list
csv_list = csv.reader(f)
print(list(csv_list))
# 以字典的格式读取数据
csv_result = csv.DictReader(f)
for user in csv_result:
print(dict(user))
csv.writer()
通常情况下,利用文本文件来保存数据,有三种数据格式可供使用: 1、CSV文件 2、XML文件 3、JSON文件
三、利用CSV修改用户密码
修改用户的密码,修改一个CSV文件中的某一行中的某一列,不能直接修改(Python中不存在文件内容部分修改的操作) 将CSV整体读入到内存中,形成列表+字典,然后修改字典的某一项,再整体写入到CSV(覆盖写入)
python
def change_password(username, newpass):
csv_list = read_csv('./userpass.csv')
for user in csv_list:
if user['username'] == username:
index = csv_list.index(user)
break
csv_list[index]['password'] = newpass
# 将列表+字典还原成行+逗号分隔数据
with open('./userpass.csv', mode='w') as f:
f.write("username,password,phone\n")
for user in csv_list:
line = f"{user['username']},{user['password']},{user['phone']}\n"
# print(line)
# line = line.replace("'","")
f.write(line)