python - 我正在尝试从 csv 转换为 json,它给出了一个错误,因为缺少值
问题描述
我正在尝试从 csv 转换为 json,但由于reader_row[10]
缺少值而出现错误。如何将缺失值替换为 Null?和写。
l = []
with open("data.csv", 'r') as data_file:
reader = csv.reader(data_file)
headers = next(reader)
for reader_row in reader:
d = {}
d[headers[11]] = str(reader_row[11])
d[headers[13]] = str(reader_row[13])
d[headers[14]] = str(reader_row[14])
d[headers[18]] = str(reader_row[18])
d[headers[3]] = int(reader_row[3])
d[headers[16]] = bool(reader_row[16])
d[headers[4]] = float(reader_row[4])
d[headers[5]] = str(reader_row[5])
d[headers[10]] = int(reader_row[10])
d[headers[17]] = int(reader_row[17])
d[headers[15]] = int(reader_row[15])
d[headers[0]]={'Address Street': str(reader_row[0]),
'Address City': str(reader_row[1]),
'Address Postcode': str(reader_row[2])
}
d[headers[8]]={'Credit Card Number': str(reader_row[8]),
'Credit Card Start Date': str(reader_row[6]),
'Credit Card Expiry Date': str(reader_row[7]),
'Credit Card CVV': int(reader_row[9]),
'Bank IBAN' : str(reader_row[12])
}
d[headers[19]]={'Vehicle Make': str(reader_row[19]),
'Vehicle Model': str(reader_row[20]),
'Vehicle Year': int(reader_row[21]),
'Vehicle Type': str(reader_row[22])
}
l.append(d)
解决方案
您可以使用条件运算符来分配None
ifreader_row[10]
为空。
d[headers[10]] = int(reader_row[10]) if reader_row[10] else None
推荐阅读
- android - 如何从图像中检测和提取符号
- ibm-midrange - IBM i:两个 *PGM 对象之间的二进制差异
- python - 解析具有特殊符号的 DataFrame &
- mysql - SQL查询将两列合二为一
- windows - 通过 PowerShell 添加 Windows 防火墙规则
- blazor - 将多个站点与我的 Blazor.Net 5 应用程序相结合
- reactjs - 使用 useState 对设置值反应火事件或火方法
- android - Android Camera2 + MediaCodec + MediaMuxer 使用持久表面?
- go - 错误“binary.Write:无效类型”是什么意思?
- xml - XSLT 1.0:同时复制结构和子结构