CSV 檔案操作- Python 教學 - STEAM 教育學習網
文章推薦指數: 80 %
Python 的標準函式「csv」提供了操作CSV 檔案的方法,可以針對CSV 檔案進行讀取、寫入或修改,這篇教學將會介紹csv 常用的方法。
CSV檔案操作
Python的標準函式「csv」提供了操作CSV檔案的方法,可以針對CSV檔案進行讀取、寫入或修改,這篇教學將會介紹csv常用的方法。
本篇使用的Python版本為3.7.12,所有範例可使用GoogleColab實作,不用安裝任何軟體(參考:使用GoogleColab,但Colab實作CSV效能較差,建議使用本機環境測試。
CSV檔案操作時,需要使用open()開啟,詳細資訊可以參考:內建函式(檔案讀寫open)。
本篇教學可使用CSV範例檔:CSV檔案下載
CSV是什麼?
CSV是一種以「逗號分隔值」的檔案格式,並以「純文字形式」儲存資料(數字和文字),CSV是一種通用並相對簡單的檔案格式,廣泛應用於使用者、商業和科學領域,因此幾乎所有的分析軟體和應用程式,都支援CSV格式。
下方所呈現的是一個簡單的CSV檔案內容,第一行可以作為普通的內容,也可以是表格的開頭:
name,id,color,price
apple,1,red,10
orange,2,orange,15
grap,3,purple,20
watermelon,4,green,30
CSV常用方法
下方列出幾種csv模組常用的方法(參考Python官方文件:CSV文件讀寫):
方法
參數
說明
reader()
csvfile
讀取CSV檔案(串列形式)。
writer()
csvfile
寫入CSV檔案(串列形式)。
DictReader()
csvfile
讀取CSV檔案(字典形式)。
DictWriter()
csvfile,fieldnames
寫入CSV檔案(字典形式)。
importcsv
要使用csv必須先importcsv模組,或使用from的方式,單獨import特定的類型。
importcsv
fromcsvimportreader
reader(csvfile)
csv.reader(csvfile)可以用「串列」的型態,讀取CSV檔案,讀取後可以使用串列的操作方式,將每一行(row)印出,
此外,還可以設定delimiter參數,針對「變種CSV格式做設定」(參考變種與格式參數)。
importos
importcsv
os.chdir('/content/drive/MyDrive/ColabNotebooks')#針對Colab改變路徑,本機環境可不用
csvfile=open('csv-demo.csv')
r=csv.reader(csvfile)#讀取csv檔案
forrowinlist(r):#將讀取的檔案,轉換成串列的方式,印出每個項目
print(row)
#['name','id','color','price']
#['apple','1','red','10']
#['orange','2','orange','15']
#['grap','3','purple','20']
#['watermelon','4','green','30']
writer(csvfile)
csv.writer(csvfile)可以用「串列」的型態,將資料寫入CSV檔案,寫入的方法分成writerow單行寫入以及writerows多行寫入兩種,下方的例子使用writerow寫入單行資料。
注意,open模式使用a+表示可以讀取檔案以及寫入資料在原本資料的最後方,因此如果CSV最後一行不為空,資料會加在最後一筆資料後方(在同一行),為了避免這個問題,可以將CSV檔案增加最後一行,或使用writerow('')加入一個空行。
importos
importcsv
os.chdir('/content/drive/MyDrive/ColabNotebooks')#針對Colab改變路徑,本機環境可不用
csvfile=open('csv-demo.csv','a+')#使用a+模式開啟檔案
r=csv.writer(csvfile)#設定r為寫入
r.writerow('')#如果原本的CSV最後一行row不為空,加入換行
#如果最後一行為空則不用
r.writerow(['banana',5,'yellow',20])#寫入單行資料
下方的例子使用writerows寫入多行資料。
importos
importcsv
os.chdir('/content/drive/MyDrive/ColabNotebooks')#針對Colab改變路徑,本機環境可不用
csvfile=open('csv-demo.csv','a+')
write=csv.writer(csvfile)
data=[#建立要寫入的資料串列
['banana',5,'yellow',20],
['papaya',6,'orange',30]
]
write.writerows(data)#寫入多行資料
DictReader(csvfile)
csv.DictReader(csvfile)可以用「字典」的型態,讀取CSV檔案,讀取後可以使用字典的操作方式,將每一行(row)印出,除了csvfile為必須填入的參數,還有下列幾個非預設的參數(不填入則使用預設值)。
參數
說明
fieldnames
預設None,會使用CSV的第一行作為字典的鍵,如果有設定則會以fieldnames的內容作為鍵。
restkey
預設None,如果有設定,某一行多出來的資料會以restkey設定值作為鍵。
restval
預設None,如果有設定,某一行缺少的資料會以restval作為值。
下方的程式碼執行後,會讀取CSV並單獨印出name、id、color和price。
importos
importcsv
os.chdir('/content/drive/MyDrive/ColabNotebooks')#針對Colab改變路徑,本機環境可不用
csvfile=open('csv-demo.csv','r')#開啟CSV檔案模式為r
data=csv.DictReader(csvfile)#以字典方式讀取資料
foriindata:
print(i['name'],i['id'],i['color'],i['price'])#分別印出不同鍵的值
#apple1red10
#orange2orange15
#grap3purple20
#watermelon4green30
#banana5yellow20
如果CSV的第一行不是標題(直接就是資料),可透過下方的程式碼,使用fieldnames加入鍵(為了明顯區隔,範例裡使用a、b、c、d),輸出結果可以看到,字典裡所有資料的鍵,都變成a、b、c、d。
importos
importcsv
os.chdir('/content/drive/MyDrive/ColabNotebooks')
csvfile=open('csv-demo.csv','r')
keys=['a','b','c','d']#手動設定字典的鍵
data=csv.DictReader(csvfile,fieldnames=keys)#設定fieldnames為keys
foriindata:
print(i)
#OrderedDict([('a','name'),('b','id'),('c','color'),('d','price')])
#OrderedDict([('a','apple'),('b','1'),('c','red'),('d','10')])
#OrderedDict([('a','orange'),('b','2'),('c','orange'),('d','15')])
#OrderedDict([('a','grap'),('b','3'),('c','purple'),('d','20')])
#OrderedDict([('a','watermelon'),('b','4'),('c','green'),('d','30')])
#OrderedDict([('a','banana'),('b','5'),('c','yellow'),('d','20')])
如果CSV的資料有多出來,或有缺漏,可以透過下方的程式碼,使用restkey或restval來補齊(圖片是有多出來以及有缺漏的CSV檔案),執行後可以看到第四筆資料多了一個more的鍵,最後一筆資料缺漏的值都變成0。
importos
importcsv
os.chdir('/content/drive/MyDrive/ColabNotebooks')
csvfile=open('csv-demo.csv','r')
data=csv.DictReader(csvfile,restkey='more',restval='0')
foriindata:
print(i)
#OrderedDict([('name','apple'),('id','1'),('color','red'),('price','10')])
#OrderedDict([('name','orange'),('id','2'),('color','orange'),('price','15')])
#OrderedDict([('name','grap'),('id','3'),('color','purple'),('price','20')])
#OrderedDict([('name','watermelon'),('id','4'),('color','green'),('price','30'),('more',['1234567'])])
#OrderedDict([('name','test'),('id','0'),('color','0'),('price','0')])
DictWriter(csvfile,fieldnames)
DictWriter(csvfile,fieldnames)可以用「字典」的型態,將資料寫入CSV檔案,寫入的方法分成writerow單行寫入以及writerows多行寫入兩種,下方的例子使用writerow寫入單筆資料。
注意,open模式使用a+表示可以讀取檔案以及寫入資料在原本資料的最後方,因此如果CSV最後一行不為空,資料會加在最後一筆資料後方(在同一行),為了避免這個問題,可以將CSV檔案增加最後一行,或使用writerow('')加入一個空行。
importos
importcsv
os.chdir('/content/drive/MyDrive/ColabNotebooks')
fieldnames=['name','id','color','price']#定義要寫入資料的鍵
data=csv.DictWriter(csvfile,fieldnames=fieldnames)#設定data為寫入資料
data.writerow({'name':'papaya','id':5,'color':'orange','price':30})#寫入資料
下方例子使用writerows寫入多筆資料,多筆資料使用「串列+字典」的形式表現
importos
importcsv
os.chdir('/content/drive/MyDrive/ColabNotebooks')
fieldnames=['name','id','color','price']#定義要寫入資料的鍵
data=csv.DictWriter(csvfile,fieldnames=fieldnames)#設定data為寫入資料
w=[
{'name':'papaya','id':5,'color':'orange','price':30},
{'name':'banana','id':6,'color':'yellow','price':20}
]
data.writerows(w)
意見回饋
如果有任何建議或問題,可傳送「意見表單」給我,謝謝~
Python教學
基本介紹
Python學習導讀
關於Python
使用GoogleColab
使用Anaconda
使用Python虛擬環境
Python範例集錦
資料型別
變數variable
變數(全域、區域)
數字number
文字與字串string
文字與字串(常用方法)
文字與字串(格式化)
串列list
串列(常用方法)
元組/數組tuple
字典dictionary
集合set
語法觀念
縮排和註解
運算子operator
邏輯判斷(if、elif、else)
邏輯判斷(and和or)
重複迴圈(for、while)
例外處理(try、except)
生成式comprehension
物件類別class
物件繼承inheritance
匯入模組import
函式操作
函式function
匿名函式lambda
遞迴recursion
產生器generator
裝飾器decorator
閉包closure
內建函式/方法
輸入與輸出
數學計算
字串操作與轉換
迭代物件轉換
迭代物件操作
檔案讀寫(open)
eval()與exec()
標準函式庫/模組
隨機數random
數學math
數學統計函式statistics
時間與日期datetime
時間處理time
日曆calendar
使用正規表達式re
檔案操作os
查找匹配檔案glob
壓縮檔案zipfile
高階檔案操作shutil
高效迭代器itertools
容器資料型態collections
CSV檔案操作
JSON檔案操作
threading多執行緒處理
concurrent.futures
網路爬蟲
Python網路爬蟲導讀
關於網路爬蟲
破解反爬蟲的方法
Requests函式庫
BeautifulSoup函式庫
Selenium函式庫
爬取PTT文章標題
自動下載PTT正妹圖片
同時下載多張圖片
爬取空氣品質指標(AQI)
爬取氣象預報
爬取現在天氣
LINENotify雷達回波圖
LINENotify即時地震資訊
爬取臺灣銀行牌告匯率
爬取Yahoo股市即時股價
爬取LINETODAY留言
批次下載Pinterest圖片
登入Mobile01截圖下載
Twitter自動上傳圖文
網頁服務與應用
Flask函式庫
使用ngrok服務
GoogleCloudFunctions
串接Gmail寄送電子郵件
讀取Google試算表
寫入Google試算表
發送LINENotify通知
使用Dialogflow
Dialogflow+Webhook
伺服器串接Dialogflow
LINEBOT教學
LINEBOT教學導讀
建立LINEChannel
設定Colab開發環境
建立並串接Webhook
解析LINE的訊息
自動回覆訊息
主動推播訊息
建立圖文選單
切換圖文選單
發送樣板訊息
發送FlexMessage
使用Requests傳送訊息
使用LINEURLScheme
氣象機器人(1)
氣象機器人(2)
氣象機器人(3)
氣象機器人(4)
串接Dialogflow(1)
串接Dialogflow(2)
串接Dialogflow(3)
串接Dialogflow(4)
OpenCV教學
OpenCV教學導讀
OpenCV函式庫
開啟並顯示圖片
寫入並儲存圖片
讀取並播放影片
寫入並儲存影片
取得影像資訊
旋轉/翻轉/改變尺寸
影像的幾何變形
影像的色彩轉換
繪製各種形狀
影像加入文字
剪裁影像
調整對比和亮度
負片效果
影像模糊化
影像的疊加與相減
二值化黑白影像
影像的侵蝕與膨脹
影像邊緣偵測
魔術棒填充顏色
影像遮罩
邊緣羽化效果
馬賽克效果
子母畫面影片
萬花筒影片效果
多畫面延遲播放影片
搞笑全景影片合成效果
凸透鏡效果(魚眼效果)
倒數計時自動拍照效果
線性漸層填色
合成半透明圖片
將指定的顏色變透明
處理gif動畫
影片轉透明gif動畫
辨識QRCode和BarCode
掃描QRCode切換效果
偵測滑鼠事件
滑鼠選取自動馬賽克
即時在影片中繪圖
偵測鍵盤行為
加入滑桿(Trackbar)
AI影像辨識教學
AI影像辨識教學導讀
OpenCV人臉偵測
OpenCV人臉馬賽克
OpenCV五官偵測
OpenCV汽車偵測
OpenCV行人偵測
OpenCV辨識不同人臉
OpenCV單物件追蹤
OpenCV多物件追蹤
OpenCV抓取特定顏色
OpenCV追蹤並標記顏色
情緒辨識與年齡偵測
辨識微笑,拍照儲存
使用Mediapipe
Mediapipe人臉偵測
Mediapipe人臉網格
Mediapipe手掌偵測
Mediapipe姿勢偵測
Mediapipe全身偵測
Mediapipe物體偵測
Mediapipe人物去背
Mediapipe手勢辨識
辨識比中指,自動馬賽克
用手指在影片中畫圖
手指擦除鏡子霧氣效果
即時合成搞笑橘子臉
Jupyter安裝Tensorflow
使用TeachableMachine
辨識剪刀、石頭、布
辨識是否戴口罩
辨識手寫數字
NumPy教學
NumPy教學導讀
NumPy函式庫
資料型態
建立陣列
讀取陣列
迭代陣列
陣列項目賦值
修改陣列形狀
修改陣列項目
填充陣列
分割陣列
合併陣列
陣列排序
廣播
搜尋陣列項目
算數計算
數學函式
隨機數
字串操作處理
matplotlib圖表
matplotlib教學導讀
matplotlib函式庫
Figure和Axes
Figure參數設定
建立多個子圖表
設定圖表標籤
設定座標軸位置
設定座標軸刻度文字
資料文字標記
加入顏色對照表
使用極座標系統
使用3D圖表
圖表顯示中文
下載儲存圖表
顯示圖片
製作圖表動畫
(圖表)折線圖
(圖表)散布圖
(圖表)長條圖
(圖表)圓餅圖
(圖表)甜甜圈圖
(圖表)等高線圖
(圖表)階梯折線圖
(圖表)堆疊折線圖
(圖表)堆疊長條圖
(圖表)極座標長條圖
(圖表)極座標散布圖
(圖表)3D柱狀長條圖
(圖表)3D散布圖
Tkinter設計介面
Tkinter教學導讀
建立Tkinter視窗
Label標籤
Button按鈕
Radiobutton單選按鈕
Checkbutton複選按鈕
Entry單行輸入框
Text多行輸入框
Listbox列表選擇框
OptionMenu下拉選單
Scale數值調整滑桿
Spinbox數值調整元件
Frame框架
LabelFrame標籤框架
Scrollbar滾動條
Canvas畫布
Menu選單
Messagebox訊息提示框
Photoimage顯示圖片
ttk.Progressbar進度條
ttk.Combobox下拉選單
Pack基本版面佈局
Grid格狀版面佈局
Place位置版面佈局
範例-Label製作時鐘
範例-點擊按鈕開檔案
範例-開啟多個檔案
範例-開啟並壓縮檔案
範例-開啟並顯示圖片
範例-調整圖片亮度對比
範例-簡單計算機
範例-發送LINENotify
PyQt5設計介面
PyQt5教學導讀
PyQt5函式庫
使用Qtdesigner
建立PyQt5視窗
QLabel標籤
QPushButton按鈕
QRadioButton單選按鈕
QCheckBox複選按鈕
QGraphicsView顯示圖片
QLineEdit單行輸入框
QTextEdit多行輸入框
QListWidget列表選擇框
QComboBox下拉選單
QSpinBox數值調整元件
QTimeEdit時間調整元件
QDateEdit日期調整元件
QSlider數值調整滑桿
QProgressBar進度條
QFileDialog選擇檔案視窗
QMessageBox對話視窗
QInputDialog輸入視窗
QMenuBar視窗選單
QTimer定時器
QThread多執行緒
QSS樣式設定
QWebEngineView網頁
Layout佈局(垂直水平)
Layout佈局(Grid網格)
Layout佈局(Form表單)
偵測滑鼠事件
偵測鍵盤與快速鍵組合
偵測與控制視窗
範例-電腦攝影機
範例-攝影機拍照錄影
範例-簡單錄音機
影音處理範例
批次圖片轉檔
批次調整圖片尺寸
調整圖片亮度和對比
裁切與旋轉圖片
拼接多張圖片
圖片加上logo浮水印
圖片加上文字浮水印
圖片馬賽克效果
圖片模糊化
圖片銳利化
讀取與修改圖片Exif
圖片轉文字(OCR)
讀取聲音資訊、輸出聲音
聲音剪輯與串接
聲音音量調整
聲音混合與反轉
改變聲音速度
播放聲音
麥克風錄音
顯示聲波圖形
影片轉檔
取出影片聲音或加入聲音
影片剪輯與合併
影片混合與排列顯示
改變影片尺寸、旋轉翻轉
調整影片速度、倒轉影片
調整影片亮度/對比/顏色
影片轉gif動畫
影片中加入文字
影片自動加上字幕
影片截圖、圖片轉影片
實際應用範例
下載Youtube影片
下載Youtube清單影片
定時自動螢幕截圖
LINENotify傳送螢幕截圖
批次重新命名檔案
產生QRCode
產生BarCode
讀取PDF內容
PDF拆分/合併/插入/刪除
讀取EXCEL內容
寫入資料到EXCEL
CSV寫入EXCEL
製作MacOSapp
基礎範例
攝氏/華氏轉換
公分/英吋換算
判斷平年與閏年
找出不重複字元
找出中間的字元
大樂透電腦選號
下載進度條
星號金字塔
數字金字塔
猜數字(猜大猜小)
猜數字(幾A幾B)
簡單時鐘(世界時間)
計算BMI數值
計算年紀(歲、月、天)
產生身分證字號(隨機)
檢查身分證字號
羅馬數字轉換
數學範例
兩個數字的四則運算
計算多個數字的總和
費波那契數列
九九乘法表
質因數分解
快速找出質數
最小公倍數(多個數字)
最大公因數(多個數字)
ZeroJudge解答
關於ZeroJudge
a001:哈囉
a002:簡易加法
a003:兩光法師占卜術
a004:文文的求婚
a005:Eva的回家作業
a006:一元二次方程式
a009:解碼器
a010:因數分解
a013:羅馬數字
a015:矩陣的翻轉
a017:五則運算
a020:身分證檢驗
a021:大數運算
a022:迴文
a024:最大公因數(GCD)
a034:二進位制轉換
a038:數字翻轉
a040:阿姆斯壯數
a042:平面圓形切割
a044:空間切割
a053:Sagit's計分程式
a054:電話客服中心
a058:MOD3
a059:完全平方和
a065:提款卡密碼
a095:麥哲倫的陰謀
a104:排序
a147:Printitall
a148:YouCannotPass?!
a149:乘乘樂
a215:明明愛數數
a216:數數愛明明
a224:明明愛明明
a225:明明愛排列
a244:新手訓練~for+if
a248:新手訓練~陣列應用
a263:日期差幾天
a271:彩色蘿蔔
a291:nAnBproblem
a410:解方程
a414:位元運算之進位篇
a417:螺旋矩陣
a524:手機之謎
a528:大數排序
a647:投資專家
a693:吞食天地
a738:最大公約數
a746:畫蛇添足
a799:正值國
a915:二維點排序
b265:Conformity
b294:經濟大恐荒
b367:翻轉世界
b374:求眾數
b511:換銅板
b558:求數列第n項
e267:GroupReverse
d073:分組報告
d294:算算算Easy
d485:我愛偶數
d827:買鉛筆
延伸文章資訊
- 1How to Use Python Csv Dictreader - Linux Hint
The DictReader () is used to read the file of the csv in the format of the dict object. Let's dis...
- 2How to parse csv formatted files using csv.DictReader?
CSV, or "comma-separated values", is a common file format for data. The csv module helps you to ....
- 3Python DictReader读写csv文件_番茄大圣的博客
准备此文档的示例代码是基于python3.5写的。 使用csv库前,先导入csv库: import csv读取内容假设csv文件的内容如下图所示,DictReader会将第一行的 ...
- 4csv --- CSV 文件读写— Python 3.8.14 說明文件
csv 模块中的 reader 类和 writer 类可用于读写序列化的数据。也可使用 DictReader 类和 DictWriter 类以字典的形式读写数据。 也參考. 该实现在“Pytho...
- 5CSV in python · 菜鳥的SaaS之旅 - wirelessr
要讀一個csv format的字串而不是檔案需要透過 StringIO ,也就是將string當成檔案。在python2和python3稍微有點差別: try: # for Python 2.x...