当前位置: 首页 > article >正文

Python办公笔记——将csv文件转Json

目录

  • 专栏导读
  • 1、背景
  • 2、库的安装
  • 3、代码1—自定义表头
  • 4、代码2—全字段
  • 5、代码3—全字段
  • 总结

专栏导读

  • 🌸 欢迎来到Python办公自动化专栏—Python处理办公问题,解放您的双手

  • 🏳️‍🌈 博客主页:请点击——> 一晌小贪欢的博客主页求关注

  • 👍 该系列文章专栏:请点击——>Python办公自动化专栏求订阅

  • 🕷 此外还有爬虫专栏:请点击——>Python爬虫基础专栏求订阅

  • 📕 此外还有python基础专栏:请点击——>Python基础学习专栏求订阅

  • 文章作者技术和水平有限,如果文中出现错误,希望大家能指正🙏

  • ❤️ 欢迎各位佬关注! ❤️

1、背景

  • 我们有时候经常会将csv文件转为json数据(本地),然后加载json数据作为匹配项,可以将里面的数据匹配给其他的表格中

2、库的安装

用途安装
无需安装无需安装无需安装

3、代码1—自定义表头

  • 数字类型可累加

def write_json_cjb_last_month(csv_file_path):
    last_cjb = {}
    with open(csv_file_path, 'r') as f:
        rows = csv.reader(f)
        header = next(rows)
        结算账号_index = header.index('结算账号-CMDM')
        地区_index = header.index('结算归属地区.1')
        小组_index = header.index('小组')
        应收金额_index = header.index('应收金额')

        for row in rows:
            结算账号 = row[结算账号_index]
            应收金额 = float(row[应收金额_index]) if row[应收金额_index].strip() else 0  # 转换为数字并处理空值

            if 结算账号 in last_cjb:
                # 如果结算账号已存在,累加应收金额
                last_cjb[结算账号]["应收金额"] = str(float(last_cjb[结算账号]["应收金额"]) + 应收金额)
            else:
                # 如果是新的结算账号,创建新记录
                last_cjb[结算账号] = {
                    "地区": row[地区_index],
                    "小组": row[小组_index],
                    "应收金额": str(应收金额)
                }

    with open('json数据/data.json', 'w', encoding='utf-8') as f:
        json.dump(last_cjb, f, ensure_ascii=False, indent=4)

write_json_cjb_last_month(csv_file_path)

4、代码2—全字段

def csv_to_json(csv_file_path):
    with open(csv_file_path, 'r',encoding='utf-8') as f:
        reader = csv.reader(f)
        header = next(reader)
        data = [dict(zip(header, row)) for row in reader]
    with open('data.json', 'w',encoding='utf-8') as f:
        json.dump(data, f, ensure_ascii=False)


csv_to_json(file_name)

5、代码3—全字段

def csv_to_json(csv_file_path, json_file_path):
    # 使用 DictReader 直接将每一行解析为字典
    with open(csv_file_path, mode='r', encoding='utf-8', newline='') as csvfile:
        reader = csv.DictReader(csvfile)
        # 打开 JSON 文件,并分块写入
        with open(json_file_path, mode='w', encoding='utf-8') as jsonfile:
            # 增加 JSON 数组的开头
            jsonfile.write('[')
            first_line = True
            for row in reader:
                # 分块写入 JSON,避免一次性将所有数据加载进内存
                if not first_line:
                    jsonfile.write(',\n')
                json.dump(row, jsonfile, ensure_ascii=False)
                first_line = False
            # 结束 JSON 数组
            jsonfile.write('\n]')

# 执行 CSV 转 JSON 的操作
csv_to_json(file_name, json_file)

# 读取生成的 JSON 文件进行验证
with open(json_file, mode='r', encoding='utf-8') as f:
    data = json.load(f)
    for i in data:
        print(i)

总结

  • 希望对初学者有帮助

  • 致力于办公自动化的小小程序员一枚

  • 希望能得到大家的【一个免费关注】!感谢

  • 求个 🤞 关注 🤞

  • 此外还有办公自动化专栏,欢迎大家订阅:Python办公自动化专栏

  • 求个 ❤️ 喜欢 ❤️

  • 此外还有爬虫专栏,欢迎大家订阅:Python爬虫基础专栏

  • 求个 👍 收藏 👍

  • 此外还有Python基础专栏,欢迎大家订阅:Python基础学习专栏


http://www.kler.cn/a/536383.html

相关文章:

  • 在 Flownex 中创建自定义工作液
  • 解决 npm : 无法加载文件 D:\nodeJS\node_global\npm.ps1,因为在此系统上禁止运行脚本。
  • Apache SeaTunnel 整体架构运行原理
  • Vue全流程--Vue2组件的理解第二部分
  • 确保数据一致性:RabbitMQ 消息传递中的丢失与重复问题详解
  • 动手学图神经网络(11):使用MovieLens数据集进行链路预测的实践
  • c#对接deepseek 聊天AI接口
  • 使用数学工具和大模型结合训练专有小模型(有限元算法和大模型微调)
  • 使用 Docker 部署 RabbitMQ 的详细指南
  • 紧跟潮流,将 DeepSeek 集成到 VSCode
  • Windows 电脑安装 mysqldump 的详细教程
  • 数据结构与算法面经
  • ZooKeeper相关知识点
  • C++ Primer 递增和递减运算符
  • 配置#include “nlohmann/json.hpp“,用于处理json文件
  • 【c++】析构函数
  • pytest-xdist 进行多进程并发测试!
  • 团建 蓝桥杯省a 15
  • AI死亡脱离控制器
  • webpack配置方式
  • DeepSeek和ChatGPT的对比
  • Compose 面试题
  • 退格法记单词(类似甘特图)
  • profinet转ModbusTCP网关,助机器人“掀起”工业智能的惊涛骇浪
  • Kruskal算法求解最小生成树
  • SQLite更新版本