【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)
相关推荐
冬奇Lab6 分钟前
每日一个开源项目(第128篇):Agent Skills - 给 AI 编程 Agent 装上工程纪律
人工智能·开源·资讯
天佑木枫14 分钟前
第2天:变量与数据类型 —— 让程序记住信息
python
Deepoch39 分钟前
Deepoc VLA开发板:采摘机器人的环境鲁棒作业与不确定性应对
人工智能·机器人·采摘机器人·deepoc
云栖梦泽在1 小时前
AI安全专项:AI人脸识别的安全风险与防护
人工智能·安全
欧阳天羲1 小时前
【开源资料】AI激光灭蚊机器人|YOLOv8数据集标注模板+完整训练配置文件一键拿走(适配ESP32-S3/树莓派双版本)
人工智能·机器人·开源
Dust-Chasing1 小时前
Claude Code源码剖析 - Claude Code 上下文压缩机制
人工智能·python·ai
甲维斯1 小时前
MiMo Code 初体验,免费,易上手,适合新手!
人工智能
2301_764441331 小时前
主流手机pc品牌的端侧模型部署梳理
人工智能·windows·机器学习·智能手机·产品运营
虾壳云智能2 小时前
阿里云百炼 API 配置 OpenClaw 2.7.9 环境搭建
人工智能·阿里云百炼·open claw安装·open claw教程