日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

一文秒懂python讀寫csv xml json文件各種騷操作

系統 1843 0

Python優越的靈活性和易用性使其成為最受歡迎的編程語言之一,尤其是對數據科學家而言。 這在很大程度上是因為使用Python處理大型數據集是很簡單的一件事情。

如今,每家科技公司都在制定數據戰略。 他們都意識到,擁有正確的數據(干凈、盡可能多)會給他們帶來關鍵的競爭優勢。 數據,如果使用有效,可以提供深層次的、隱藏在表象之下的信息。

多年來,數據存儲的可能格式顯著增加,但是,在日常使用中,還是以 CSV 、 JSON 和 XML 占主導地位。 在本文中,我將與你分享在Python中使用這三種流行數據格式及其之間相互轉換的最簡單方法!

CSV 數據

CSV文件是存儲數據的最常見方式,你會發現,Kaggle競賽中的大多數數據都是以這種方式存儲的。 我們可以使用Python內置的csv庫讀寫CSV文件,通常,我們將數據讀入一個列表中,列表中每個元素又是一個列表,代表一行數據。

觀察下面的代碼,當我們運行 csv.reader() 時,就可以訪問到我們指定的CSV數據文件。 而 csvreader.next() 函數的作用是從CSV中讀取一行,每次調用它,它都會移動到下一行。 我們還可以通過 for row in csvreader 使用for循環遍歷csv的每一行。 另外,最好確保每一行的列數相同,否則,在處理列表時可能會遇到一些錯誤。

            
import csv filename = "my_data.csv" fields = [] rows = [] # 讀取csv文件 with open(filename, 'r') as csvfile: # 創建一個csv reader對象 csvreader = csv.reader(csvfile) # 從文件中第一行中讀取屬性名稱信息 # fields = next(csvreader) python3.2 以上的版本使用 fields = csvreader.next() # 接著一行一行讀取數據 for row in csvreader: rows.append(row) # 打印前5行信息 for row in rows[:5]: print(row)
          

在Python將數據寫入CSV也很容易,在一個單獨的列表中設置屬性名稱,并將要寫入的數據存儲在一個列表中。 這一次,我們將創建一個 writer() 對象,并使用它將數據寫入文件,這與我們讀取數據的方式非常相似。

            
import csv # 屬性名稱 fields = ['Name', 'Goals', 'Assists', 'Shots'] # csv文件中每一行的數據,一行為一個列表 rows = [ ['Emily', '12', '18', '112'], ['Katie', '8', '24', '96'], ['John', '16', '9', '101'], ['Mike', '3', '14', '82']] filename = "soccer.csv" # 將數據寫入到csv文件中 with open(filename, 'w+') as csvfile: # 創建一個csv writer對象 csvwriter = csv.writer(csvfile) # 寫入屬性名稱 csvwriter.writerow(fields) # 寫入數據 csvwriter.writerows(rows)
          

當然,使用強大的pandas庫將會使處理數據變得容易很多,從CSV讀取和寫入文件都只需要一行代碼!

            
import pandas as pd filename = "my_data.csv" # 讀取csv文件數據 data = pd.read_csv(filename) # 打印前5行 print(data.head(5)) # 將數據寫入到csv文件中 data.to_csv("new_data.csv", sep=",", index=False)
          

我們甚至可以使用pandas通過一行代碼快速將CSV轉換為字典列表。 轉換為字典列表之后,我們可以使用 dicttoxml 庫將其轉換為XML格式,我們還可以將它保存為JSON文件!

            
import pandas as pd from dicttoxml import dicttoxml import json # 創建一個DataFrame data = {'Name': ['Emily', 'Katie', 'John', 'Mike'], 'Goals': [12, 8, 16, 3], 'Assists': [18, 24, 9, 14], 'Shots': [112, 96, 101, 82] } df = pd.DataFrame(data, columns=data.keys()) # 將DataFrame轉化為一個字典并且將它存儲到json文件中 data_dict = df.to_dict(orient="records") with open('output.json', "w+") as f: json.dump(data_dict, f, indent=4) # 將DataFrame轉化為一個字典并且將它存儲到xml文件中 xml_data = dicttoxml(data_dict).decode() with open("output.xml", "w+") as f: f.write(xml_data)
          

JSON數據

JSON提供了一種干凈且易于閱讀的格式,因為它維護了一個字典風格的結構。 就像CSV一樣,Python有一個內置的json模塊,使讀寫變得超級容易! 從上面的例子可以看到當我們讀取CSV時,可以將數據以字典的形式存儲,然后再將字典寫入文件。

            
import json import pandas as pd # 使用json模塊從json文件中讀取數據 # 以字典形式存儲 with open('data.json') as f: data_listofdict = json.load(f) # 也可以直接使用pandas直接讀取json文件 data_df = pd.read_json('data.json', orient='records') # 將字典數據保存為json文件 # 并使用 'indent' and 'sort_keys' 格式化json文件 with open('new_data.json', 'w+') as json_file: json.dump(data_listofdict, json_file, indent=4, sort_keys=True) # 也可以使用pandas將字典結構的數據保存為json文件 export = data_df.to_json('new_data.json', orient='records')
          

正如我們之前看到的,我們可以通過pandas或者使用Python的內置csv模塊輕松地將我們的數據存儲為CSV文件,而在轉化為成XML時,我們使用的是 dicttoxml 庫。

            
import json import pandas as pd import csv # 從json文件中讀取數據 # 數據存儲在一個字典列表中 with open('data.json') as f: data_listofdict = json.load(f) # 以列表中的字典寫入倒csv文件中 keys = data_listofdict[0].keys() with open('saved_data.csv', 'w') as output_file: dict_writer = csv.DictWriter(output_file, keys) dict_writer.writeheader() dict_writer.writerows(data_listofdict)
          

XML數據

XML有點不同于CSV和JSON。 通常,CSV和JSON由于其簡單性而被廣泛使用。 它們讀、寫和解釋起來既簡單又快捷,不需要額外的工作,而且解析JSON或CSV是非常輕量級的。

另一方面,XML往往數據量要大一些。 你如果正在發送更多的數據,這意味著你需要更多的帶寬、更多的存儲空間和更多的運行時間。 但是與JSON和CSV相比,XML確實具有一些額外的特性: 你可以使用名稱空間來構建和共享標準結構、更好的繼承表示,以及用XML schema、DTD等表示數據的行業標準化方法。

要讀取XML數據,我們將使用Python內置的XML模塊的子模塊ElementTree。 這里,我們可以使用 xmltodict 庫將ElementTree對象轉換為字典。 一旦有了字典,我們就可以像上面一樣將字典換轉換為CSV、JSON或pandas的 DataFrame !

            
import xml.etree.ElementTree as ET import xmltodict import json tree = ET.parse('output.xml') xml_data = tree.getroot() xmlstr = ET.tostring(xml_data, encoding='utf8', method='xml') data_dict = dict(xmltodict.parse(xmlstr)) print(data_dict) with open('new_data_2.json', 'w+') as json_file: json.dump(data_dict, json_file, indent=4, sort_keys=True)
          

總結

以上所述是小編給大家介紹的一文綜述python讀寫csv xml json文件各種騷操作,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 娄烦县| 沧州市| 南开区| 哈巴河县| 石棉县| 新宾| 湟中县| 馆陶县| 石城县| 云和县| 新竹市| 马龙县| 南召县| 牙克石市| 敦煌市| 永顺县| 福海县| 四会市| 山西省| 蕲春县| 汉中市| 永春县| 工布江达县| 龙井市| 保山市| 金堂县| 旬阳县| 平陆县| 泰来县| 呼伦贝尔市| 蒙城县| 建瓯市| 长汀县| 文水县| 施秉县| 永福县| 湛江市| 莒南县| 辽阳县| 清涧县| 霍山县|