今天我們進行了csv和json格式互換的實驗。CSV和JSON都是常見的數(shù)據(jù)格式,CSV是一種以逗號為分隔符,以行為記錄分割的文本文件格式,常用于表示表格類型數(shù)據(jù)。而JSON是一種簡單的文本數(shù)據(jù)交換格式,常用于傳輸結(jié)構(gòu)化數(shù)據(jù)。
在實驗開始前,我們先了解了一些Python處理CSV和JSON文件的庫,包括csv、json和pandas等。csv和json庫都是Python內(nèi)置的,而pandas庫則需要額外安裝。
我們首先用pandas讀取一個csv文件,并將其轉(zhuǎn)換成json格式,代碼如下:
import pandas as pd df = pd.read_csv('file.csv') json_str = df.to_json(orient='records') print(json_str)
這里我們使用了pandas庫提供的to_json方法將DataFrame對象轉(zhuǎn)換為JSON格式。orient參數(shù)指定了輸出的JSON格式,這里為records,表示每一行作為一個記錄。
接下來,我們通過json庫將一個json文件轉(zhuǎn)換為csv格式,代碼如下:
import json import csv json_str = '{"name": "Alice", "age": 20, "gender": "female"}' json_obj = json.loads(json_str) csv_file = open('file.csv', 'w') csv_writer = csv.writer(csv_file) for key, val in json_obj.items(): csv_writer.writerow([key, val]) csv_file.close()
這里我們先使用json庫將json字符串轉(zhuǎn)換為JSON對象,然后通過csv庫將其寫入到csv文件中。其中,csv.writer方法將數(shù)據(jù)寫入到csv文件中,csv.writerow方法將一行數(shù)據(jù)寫入到csv文件中,并使用逗號作為分隔符。
經(jīng)過這次實驗,我們學(xué)會了如何使用Python處理CSV和JSON文件,并成功完成了CSV和JSON格式的互換。