py实现CSV转json

import sys
import json
import csv
import chardet

# input_file = sys.argv[1]
input_file =   "./tab_airspace_data.csv"
lines = ""

def detect_encoding(file_path):
    with open(file_path, 'rb') as f:
        result = chardet.detect(f.read())
    return result['encoding']
# 使用检测到的编码来读取文件
encoding = detect_encoding(input_file)

# 读取文件
with open(input_file, "r",encoding= encoding) as f:
    reader = csv.reader(f)
    # 创建一个空列表
    keys = []  
    datas = []
    index = 0
    # 遍历每一行,包含索引
    for row in reader:
        # 把数组row用#连接成字符串
        if(index == 0):
            keys = row
        else:
            
          datas.append(dict(zip(keys, row))) 
        index+=1  
# 序列化时对中文默认使用的ascii编码.想输出真正的中文需要指定ensure_ascii=False

json_str = json.dumps(datas, ensure_ascii=False, indent=4)
# 去除\",\\N,\n 无关符号
result_data = json_str.replace(r'\"','').replace(r'\\N','').replace(r'\n','')
output_file = input_file.replace("csv", "json")
# 写入文件
with open(output_file, "w", encoding="utf-8") as f:
    f.write(result_data)
    print("convert success")
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

twinkle||cll

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值