目錄
- 什么是CSV文件及其用途?
- 為什么使用CSV文件格式?
- Python CSV模塊
- CSV模塊功能
- Python中CSV文件的操作
- 在Python中讀取CSV文件:
- 用Python寫(xiě)入CSV文件:
- 讀取CSV文件作為字典:
- 作為字典寫(xiě)入CSV文件
- 以熊貓格式讀取CSV文件:
您知道將表格數(shù)據(jù)存儲(chǔ)到純文本文件背后的機(jī)制是什么嗎?答案是CSV(逗號(hào)分隔值)文件,該文件允許將數(shù)據(jù)轉(zhuǎn)換為純文本格式。在這篇文章中關(guān)于“在Python如何閱讀CSV文件”中,我們將學(xué)習(xí)如何讀,寫(xiě)和解析的CSV文件的Python。
將詳細(xì)討論以下方面:
- 什么是CSV文件及其用途?
- 為什么使用CSV文件格式?
- Python CSV模塊
CSV模塊功能
- 在Python中執(zhí)行寫(xiě)入,讀取CSV文件的操作
- 讓我們開(kāi)始吧。
什么是CSV文件及其用途?
CSV(逗號(hào)分隔值)是一種純文本文件格式,用于存儲(chǔ)表格數(shù)據(jù)(例如電子表格或數(shù)據(jù)庫(kù))。它本質(zhì)上存儲(chǔ)的表格數(shù)據(jù)包括數(shù)字和純文本。大多數(shù)在線服務(wù)使用戶(hù)可以自由地將網(wǎng)站中的數(shù)據(jù)導(dǎo)出為CSV文件格式。CSV文件通常會(huì)在Excel中打開(kāi),幾乎所有數(shù)據(jù)庫(kù)都具有不同的特定工具以允許導(dǎo)入相同的文件。
文件的每一行都稱(chēng)為記錄。每個(gè)記錄由用逗號(hào)分隔 的字段組成,這些字段也稱(chēng)為“定界符”,這是默認(rèn)定界符,其他記錄包括pipe(|),分號(hào)(;)。下面給出的是一個(gè)普通CSV文件的結(jié)構(gòu),以逗號(hào)分隔,我正在使用一個(gè)泰坦尼克號(hào)CSV文件。
結(jié)構(gòu)
Passenger,Id,Survived,Pclass,Name,Sex.Age
1,0,3 Braund, Mr. Owen Harris ,male, 22
2,1,1 Cumings, Mrs. John Bradley (Florence Briggs Thayer), female,38
3,1,3 Heikkinen, Miss. Laina ,female, 26
4,1,1 Futrelle, Mrs. Jacques Heath (Lily May Peel),female,35
繼續(xù)說(shuō)說(shuō)使用CSV文件格式的原因。
為什么使用CSV文件格式?
CSV是純文本文件,它使數(shù)據(jù)交換更容易,也更易于導(dǎo)入到電子表格或數(shù)據(jù)庫(kù)存儲(chǔ)中。例如:您可能希望將某個(gè)統(tǒng)計(jì)分析的數(shù)據(jù)導(dǎo)出到CSV文件,然后將其導(dǎo)入電子表格以進(jìn)行進(jìn)一步分析。總體而言,它使用戶(hù)可以通過(guò)編程輕松地體驗(yàn)工作。任何支持文本文件或字符串操作的語(yǔ)言(例如Python)都可以直接使用CSV文件。
繼續(xù)前進(jìn),讓我們看看Python如何原生使用CSV。
Python CSV模塊
Python使用的CSV軟件包是標(biāo)準(zhǔn)庫(kù)的一部分,因此您無(wú)需安裝它。
現(xiàn)在,讓我向您展示不同的CSV功能。
CSV模塊功能
在CSV模塊下,您可以找到以下功能:

讓我們繼續(xù)前進(jìn),從Python CSV文件上不同操作的編碼角度來(lái)看。
Python中CSV文件的操作
加載CSV文件后,您可以執(zhí)行多種操作。我將在Python中顯示對(duì)CSV文件的讀取和寫(xiě)入操作。
在Python中讀取CSV文件:
import csv
with open('Titanic.csv','r') as csv_file: #Opens the file in read mode
csv_reader = csv.reader(csv_file) # Making use of reader method for reading the file
for line in csv_reader: #Iterate through the loop to read line by line
print(line)
輸出:

在這里,從輸出中可以看到,我已經(jīng)使用了Titanic CSV File。并且所有字段都用逗號(hào)分隔,文件被讀入Python。
繼續(xù)前進(jìn),讓我們看看如何寫(xiě)入CSV文件。
用Python寫(xiě)入CSV文件:
import csv
with open('Titanic.csv', 'r') as csv_file:
csv_reader = csv.reader(csv_file)
with open('new_Titanic.csv', 'w') as new_file: # Open a new file named 'new_titanic.csv' under write mode
csv_writer = csv.writer(new_file, delimiter=';') #making use of write method
for line in csv_reader: # for each file in csv_reader
csv_writer.writerow(line) #writing out to a new file from each line of the original file
out:

現(xiàn)在,這種使用讀寫(xiě)器方法處理CSV文件的方法是最常見(jiàn)的方法之一。讓我們繼續(xù)前進(jìn),看看如何使用python字典來(lái)做同樣的事情。
讀取CSV文件作為字典:
import csv
with open('Titanic.csv','r') as csv_file: #Open the file in read mode
csv_reader = csv.DictReader(csv_file) #use dictreader method to reade the file in dictionary
for line in csv_reader: #Iterate through the loop to read line by line
print(line)
輸出:

從輸出中可以看到,字段已被替換,它們現(xiàn)在充當(dāng)字典的“鍵”。
讓我們看看如何將CSV文件作為字典寫(xiě)入。
作為字典寫(xiě)入CSV文件
import csv
mydict = [{'Passenger':'1', 'Id':'0', 'Survived':'3'}, #key-value pairs as dictionary obj
{'Passenger':'2', 'Id':'1', 'Survived':'1'},
{'Passenger':'3', 'Id':'1', 'Survived':'3'}]
fields = ['Passenger', 'Id', 'Survived'] #field names
filename = 'new_Titanic.csv' #name of csv file
with open('new_Titanic.csv', 'w')as new_csv_file: #open a new file 'new_titanic,csv' under write mode
writer = csv.DictWriter(new_csv_file, fieldnames=fields)
writer.writeheader() #writing the headers(field names)
writer.writerows(mydict) #writing data rows
輸出:

讓我們看看如何在python中將CSV文件讀取為熊貓。
以熊貓格式讀取CSV文件:
import pandas #install pandas package
result = pandas.read_csv('Titanic.csv') #read the csv file
print(result) # print result
輸出:

這使我們到文章“如何在Python中讀取CSV文件”的結(jié)尾。我希望您對(duì)與CSV相關(guān)的所有概念,如何讀寫(xiě)它,如何將CSV作為字典進(jìn)行讀寫(xiě)以及如何將CSV作為熊貓進(jìn)行閱讀都一目了然。
確保盡可能多地練習(xí)并恢復(fù)經(jīng)驗(yàn)。
以上就是python 如何讀、寫(xiě)、解析CSV文件的詳細(xì)內(nèi)容,更多關(guān)于python 讀寫(xiě)解析CSV文件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
您可能感興趣的文章:- Python pandas讀取CSV文件的注意事項(xiàng)(適合新手)
- 使用Python pandas讀取CSV文件應(yīng)該注意什么?
- python 如何把classification_report輸出到csv文件
- Python批量將csv文件轉(zhuǎn)化成xml文件的實(shí)例
- python刪除csv文件的行列
- 使用python把json文件轉(zhuǎn)換為csv文件
- python讀寫(xiě)數(shù)據(jù)讀寫(xiě)csv文件(pandas用法)
- Python將list元素轉(zhuǎn)存為CSV文件的實(shí)現(xiàn)
- 利用python 讀寫(xiě)csv文件
- Python如何讀寫(xiě)CSV文件
- 如何運(yùn)用python讀寫(xiě)CSV文件