【Python与AI基础】Python编程基础:读写CSV文件

【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)
相关推荐
童话名剑8 分钟前
训练词嵌入(吴恩达深度学习笔记)
人工智能·深度学习·word2vec·词嵌入·负采样·嵌入矩阵·glove算法
桂花很香,旭很美40 分钟前
智能体技术架构:从分类、选型到落地
人工智能·架构
HelloWorld__来都来了1 小时前
2026.1.30 本周学术科研热点TOP5
人工智能·科研
共享家95271 小时前
搭建 AI 聊天机器人:”我的人生我做主“
前端·javascript·css·python·pycharm·html·状态模式
aihuangwu2 小时前
豆包图表怎么导出
人工智能·ai·deepseek·ds随心转
Hgfdsaqwr2 小时前
Python在2024年的主要趋势与发展方向
jvm·数据库·python
YMWM_2 小时前
深度学习中模型的推理和训练
人工智能·深度学习
中二病码农不会遇见C++学姐2 小时前
文明6-mod制作-游戏素材AI生成记录
人工智能·游戏
一晌小贪欢2 小时前
Python 测试利器:使用 pytest 高效编写和管理单元测试
python·单元测试·pytest·python3·python测试
小文数模2 小时前
2026年美赛数学建模C题完整参考论文(含模型和代码)
python·数学建模·matlab