【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)
相关推荐
科技小花6 小时前
全球化深水区,数据治理成为企业出海 “核心竞争力”
大数据·数据库·人工智能·数据治理·数据中台·全球化
X56617 小时前
如何在 Laravel 中正确保存嵌套动态表单数据(主服务与子服务)
jvm·数据库·python
zhuiyisuifeng7 小时前
2026前瞻:GPTimage2镜像官网或将颠覆视觉创作
人工智能·gpt
徐健峰7 小时前
GPT-image-2 热门玩法实战(一):AI 看手相 — 一张手掌照片生成专业手相分析图
人工智能·gpt
weixin_370976357 小时前
AI的终极赛跑:进入AGI,还是泡沫破灭?
大数据·人工智能·agi
Slow菜鸟8 小时前
AI学习篇(五) | awesome-design-md 使用说明
人工智能·学习
ZhengEnCi8 小时前
03ab-PyTorch安装教程 📚
python
冬奇Lab8 小时前
RAG 系列(五):Embedding 模型——语义理解的核心
人工智能·llm·aigc
深小乐8 小时前
AI 周刊【2026.04.27-05.03】:Anthropic 9000亿美元估值、英伟达死磕智能体、中央重磅定调AI
人工智能
码点滴8 小时前
什么时候用 DeepSeek V4,而不是 GPT-5/Claude/Gemini?
人工智能·gpt·架构·大模型·deepseek