国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

Python中csv模塊的基本使用教程

瀏覽:78日期:2022-06-15 09:03:20
1、csv簡介

CSV (Comma Separated Values) ,即逗號分隔值(也稱字符分隔值,因?yàn)榉指舴梢圆皇嵌禾枺且环N常用的文本

格式,用以存儲(chǔ)表格數(shù)據(jù),包括數(shù)字或者字符。很多程序在處理數(shù)據(jù)時(shí)都會(huì)碰到csv這種格式的文件,它的使用是比

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

格式時(shí)常常會(huì)碰到麻煩,幸好python內(nèi)置了csv模塊。下面簡單介紹csv模塊中最常用的一些函數(shù)。

更多內(nèi)容請參考:https://docs.python.org/2/library/csv.html#module-csv

2、csv模塊中的函數(shù)

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

參數(shù)說明:

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

dialect,編碼風(fēng)格,默認(rèn)為excel的風(fēng)格,也就是用逗號(,)分隔,dialect 方式也支持自定義,通過調(diào)用register_dialect方法來注冊,下文會(huì)提到。

fmtparam,格式化參數(shù),用來覆蓋之前dialect對象指定的編碼風(fēng)格。

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

’test.csv’是文件名,‘rb’中的r表示“讀”模式,因?yàn)槭俏募ο螅约印産’。open()返回了一個(gè)文件對象

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

reader對象lines,lines是一個(gè)list,當(dāng)調(diào)用它的方法lines.next()時(shí),會(huì)返回一個(gè)string。上面程序的效果是將csv

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

在我的test.csv文件中,存儲(chǔ)的數(shù)據(jù)如圖:

Python中csv模塊的基本使用教程

程序輸出:

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

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

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

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

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()函數(shù)打開當(dāng)前路徑下的名字為’t.csv’的文件,如果不存在這個(gè)文件,則創(chuàng)建它,返回myFile文件對象。

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

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

注意:如果文件’t.csv’事先存在,調(diào)用writer函數(shù)會(huì)先清空原文件中的文本,再執(zhí)行writerow/writerows方法。

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

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

這個(gè)函數(shù)是用來自定義dialect的。

參數(shù)說明:

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

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

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

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

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

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

在我test.csv中存儲(chǔ)如下數(shù)據(jù):

Python中csv模塊的基本使用教程

以’mydialect’風(fēng)格打印:

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’]

可以看到,現(xiàn)在是以’|’為分隔符,1和2合成了一個(gè)字符串(因?yàn)?和2之間的分隔符是逗號,而mydialect風(fēng)格的分隔

符是’|’),3單獨(dú)一個(gè)字符串。

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

unregister_dialect(name)

這個(gè)函數(shù)用于注銷自定義的dialect

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

簡單,可以自己試試。比如list_dialects()函數(shù)會(huì)列出當(dāng)前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的值。

先寫到這,其他的以后用到再更新。

總結(jié)

到此這篇關(guān)于Python中csv模塊基本使用的文章就介紹到這了,更多相關(guān)Python csv模塊使用內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 91久久国产精品视频 | 欧美一级毛片100部 欧美一级毛片aaaaa | 国产精品成人一区二区 | 超薄肉色丝袜精品足j福利 超级乱淫视频aⅴ播放视频 | 欧美亚洲国产成人不卡 | 三级黄色毛片网站 | 日韩中文字幕视频 | 欧美成人免费高清网站 | 91欧洲在线视精品在亚洲 | 国产亚洲综合精品一区二区三区 | 亚洲一区二区三区欧美 | 久久精品综合 | 久久成人免费视频 | 在线视频观看国产 | 欧洲成人在线视频 | 国产a级特黄的片子视频 | 国产黄色三级三级三级 | 91年精品国产福利线观看久久 | 精品国产一区二区三区2021 | 久久91亚洲精品中文字幕奶水 | 淫模 | 国产美女主播一级成人毛片 | 九九色视频在线观看 | 成人做爰视频www片 成人做爰视频www视频 | 手机看片久久国产免费不卡 | 一区免费在线观看 | 国产在亚洲线视频观看 | 欧美另类高清xxxxx | 国产午夜精品理论片影院 | 97在线视频免费观看 | 亚洲天堂久久 | 亚洲国产精品一区二区首页 | 毛片大全在线 | 亚洲另类激情综合偷自拍图 | 俄罗斯a级毛片 | 国产高清一区二区三区免费视频 | 久草免费手机视频 | 精品国产一区二区三区四区vr | 日韩国产在线观看 | 欧美同性videos在线可播放 | 成人永久福利在线观看不卡 |