日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

Python csv模块的使用

發布時間:2025/3/20 python 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Python csv模块的使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1、csv簡介

CSV (Comma Separated Values),即逗號分隔值(也稱字符分隔值,因為分隔符可以不是逗號),是一種常用的文本

格式,用以存儲表格數據,包括數字或者字符。很多程序在處理數據時都會碰到csv這種格式的文件,它的使用是比

較廣泛的(Kaggle上一些題目提供的數據就是csv格式),csv雖然使用廣泛,但卻沒有通用的標準,所以在處理csv

格式時常常會碰到麻煩,幸好python內置了csv模塊。下面簡單介紹csv模塊中最常用的一些函數。

2、csv模塊中的函數

  • reader(csvfile, dialect=‘excel’, **fmtparams)

參數說明:

csvfile,必須是支持迭代(Iterator)的對象,可以是文件(file)對象或者列表(list)對象,如果是文件對
象,打開時需要加"b"標志參數。

dialect,編碼風格,默認為excel的風格,也就是用逗號(,)分隔,dialect方式也支持自定義,通過調用register_dialect方法來注冊,下文會提到。

fmtparam,格式化參數,用來覆蓋之前dialect對象指定的編碼風格。

import csv with open('test.csv','rb') as myFile: lines=csv.reader(myFile) for line in lines: print line

'test.csv’是文件名,‘rb’中的r表示“讀”模式,因為是文件對象,所以加‘b’。open()返回了一個文件對象

myFile,reader(myFile)只傳入了第一個參數,另外兩個參數采用缺省值,即以excel風格讀入。reader()返回一個

reader對象lines,lines是一個list,當調用它的方法lines.next()時,會返回一個string。上面程序的效果是將csv

文件中的文本按行打印,每一行的元素都是以逗號分隔符’,'分隔得來。

在我的test.csv文件中,存儲的數據如圖:


程序輸出:

['1', '2'] ['3', 'a'] ['4', 'b']

補充:reader對象還提供一些方法:line_num、dialect、next()

  • writer(csvfile, dialect=‘excel’, **fmtparams)

參數的意義同上,這里不贅述,直接上例程:

''' 遇到問題沒人解答?小編創建了一個Python學習交流QQ群:579817333 尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書! ''' with open('t.csv','wb') as myFile: myWriter=csv.writer(myFile) myWriter.writerow([7,'g']) myWriter.writerow([8,'h']) myList=[[1,2,3],[4,5,6]] myWriter.writerows(myList)

'w’表示寫模式。

首先open()函數打開當前路徑下的名字為’t.csv’的文件,如果不存在這個文件,則創建它,返回myFile文件對象。

csv.writer(myFile)返回writer對象myWriter。

writerow()方法是一行一行寫入,writerows方法是一次寫入多行。

注意:如果文件’t.csv’事先存在,調用writer函數會先清空原文件中的文本,再執行writerow/writerows方法。

補充:除了writerow、writerows,writer對象還提供了其他一些方法:writeheader、dialect

  • register_dialect(name, [dialect, ]**fmtparams)

這個函數是用來自定義dialect的。

參數說明:

name,你所自定義的dialect的名字,比如默認的是’excel’,你可以定義成’mydialect’

[dialect, ]**fmtparams,dialect格式參數,有delimiter(分隔符,默認的就是逗號)、quotechar、

quoting等等,可以參考Dialects and Formatting Parameters

csv.register_dialect('mydialect',delimiter='|', quoting=csv.QUOTE_ALL)

上面一行程序自定義了一個命名為mydialect的dialect,參數只設置了delimiter和quoting這兩個,其他的仍然采用

默認值,其中以’|'為分隔符。接下來我們就可以像使用’excel’一樣來使用’mydialect’了。我們來看看效果:

在我test.csv中存儲如下數據:.

以’mydialect’風格打印:

''' 遇到問題沒人解答?小編創建了一個Python學習交流QQ群:579817333 尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書! ''' with open('test.csv','rb') as myFile: lines=csv.reader(myFile,'mydialect') print lines.line_num for line in lines: print line

輸出:

['1,2', '3'] ['4,5', '6']

可以看到,現在是以’|'為分隔符,1和2合成了一個字符串(因為1和2之間的分隔符是逗號,而mydialect風格的分隔

符是’|’),3單獨一個字符串。

對于writer()函數,同樣可以傳入mydialect作為參數,這里不贅述。

  • unregister_dialect(name)

這個函數用于注銷自定義的dialect

此外,csv模塊還提供get_dialect(name)、list_dialects()、field_size_limit([new_limit])等函數,這些都比較

簡單,可以自己試試。比如list_dialects()函數會列出當前csv模塊里所有的dialect:

print csv.list_dialects()

輸出:

['excel-tab', 'excel', 'mydialect']

'mydialect’是自定義的,‘excel-tab’, 'excel’都是自帶的dialect,其中’excel-tab’跟’excel’差不多,

只不過它以tab為分隔符。

csv模塊還定義了

一些類:DictReader、DictWriter、Dialect等,DictReader和DictWriter類似于reader和writer。

一些常量:QUOTE_ALL、QUOTE_MINIMAL、.QUOTE_NONNUMERIC等,這些常量可以作為Dialects and Formatting Parameters的值。

總結

以上是生活随笔為你收集整理的Python csv模块的使用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产精品毛片一区二区三区 | 国产精品入口66mio男同 | 亚洲一区二区三区麻豆 | 夜夜超碰| 一个人看的毛片 | 国产又大又长又粗 | 日韩三级一区 | 91亚洲精品国偷拍 | 国产不卡av在线 | 一区二区三区在线观看免费 | 天堂网在线观看视频 | 亚洲黄色片 | 人人射av| 强开乳罩摸双乳吃奶羞羞www | 99精品视频一区二区三区 | 日本高清有码视频 | 久久综合成人网 | 天堂亚洲网 | 亚洲女人天堂 | 国产视频污| 天天干天天草 | 国产亚洲天堂 | 少妇视频 | 国色天香av| 久久福利精品 | 成人深夜电影 | 久久色资源网 | 69xxxx日本 | 国产精品无码天天爽视频 | 亚洲天堂第一区 | 黄色免费观看网站 | 国产精品久久久久久69 | www三级| 国产成人亚洲综合 | 天天干天天色天天射 | 九九精品免费 | 天天综合在线观看 | 国产午夜精品理论片在线 | 国产在线观 | 1024精品一区二区三区日韩 | 少妇精品无码一区二区 | 影音先锋天堂网 | 97精品一区二区三区 | 午夜久久网 | 天堂网在线播放 | 久久夜夜夜 | 91成人免费 | 国产一区麻豆 | 青青草97国产精品麻豆 | 成人欧美一级特黄 | 亚洲精品综合久久 | 野花视频免费在线观看 | 后进极品美女白嫩翘臀 | 91精品视频免费观看 | 中国黄色片子 | 日韩精品极品视频免费观看 | 啪啪影音 | 黄页免费视频 | 中文字幕亚洲第一 | 韩国性猛交╳xxx乱大交 | 91视频在线观看免费 | 精品人妻人伦一区二区有限公司 | 欧美大白屁股 | 久久丁香 | 不卡影院一区二区 | 黄色一级黄色片 | 日韩特级片 | 国产在线1区 | 美国美女黄色片 | 欧美xo影院| 91久久极品少妇xxxxⅹ软件 | 国产ts系列 | 好看的黄色录像 | 色小说在线观看 | 亚洲免费高清 | 亚洲女同二女同志 | 少妇高清精品毛片在线视频 | av片观看 | 日本小视频网站 | 国产伦精品一区二区三区四区视频 | 久久香蕉网站 | 北岛玲av| 末路1997全集免费观看完整版 | 黄色一二三区 | 日韩综合第一页 | 森泽佳奈av | 九一国产在线 | 男人舔女人下部高潮全视频 | 久久久久亚洲精品 | 在线se | jizz日本在线播放 | 亚洲精品91在线 | 91久精品 | 中文字幕理论片 | 97碰| 欧美性猛交富婆 | www.999热 | 精品久久久久一区二区 | 午夜激情在线 |