亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2021年07月14日 15:16:43   作者:wepon_  
csv文件使用逗號(hào)分割,是一種純文本格式,不能指定字體顏色等樣式,也不能指定單元格的寬高,不能合并單元格,沒(méi)有多個(gè)工作表等功能,可以使用Excel打,這篇文章主要給大家介紹了關(guān)于Python中csv模塊的基本使用教程,需要的朋友可以參考下

1、csv簡(jiǎn)介

CSV (Comma Separated Values) ,即逗號(hào)分隔值(也稱字符分隔值,因?yàn)榉指舴梢圆皇嵌禾?hào)),是一種常用的文本

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

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

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

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

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

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

參數(shù)說(shuō)明:

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

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

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

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

'test.csv'是文件名,‘rb'中的r表示“讀”模式,因?yàn)槭俏募?duì)象,所以加‘b'。open()返回了一個(gè)文件對(duì)象

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

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

文件中的文本按行打印,每一行的元素都是以逗號(hào)分隔符','分隔得來(lái)。

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

程序輸出:

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

補(bǔ)充:reader對(duì)象還提供一些方法: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'表示寫(xiě)模式。

首先open()函數(shù)打開(kāi)當(dāng)前路徑下的名字為't.csv'的文件,如果不存在這個(gè)文件,則創(chuàng)建它,返回myFile文件對(duì)象。

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

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

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

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

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

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

參數(shù)說(shuō)明:

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

[dialect, ]**fmtparams,dialect格式參數(shù),有delimiter(分隔符,默認(rèn)的就是逗號(hào))、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)值,其中以'|'為分隔符。接下來(lái)我們就可以像使用'excel'一樣來(lái)使用'mydialect'了。我們來(lái)看看效果:

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

以'mydialect'風(fēng)格打?。?/p>

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之間的分隔符是逗號(hào),而mydialect風(fēng)格的分隔

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

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

unregister_dialect(name)

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

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

簡(jiǎn)單,可以自己試試。比如list_dialects()函數(shù)會(huì)列出當(dāng)前csv模塊里所有的dialect:

print csv.list_dialects()

輸出:

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

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

只不過(guò)它以tab為分隔符。

csv模塊還定義了

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

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

先寫(xiě)到這,其他的以后用到再更新。

總結(jié)

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

相關(guān)文章

  • PyTorch中可視化工具的使用

    PyTorch中可視化工具的使用

    本文主要介紹了PyTorch中可視化工具的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • Python做圖像處理及視頻音頻文件分離和合成功能

    Python做圖像處理及視頻音頻文件分離和合成功能

    這篇文章主要介紹了Python做圖像處理及視頻音頻文件分離和合成功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-11-11
  • vue.js實(shí)現(xiàn)輸入框輸入值內(nèi)容實(shí)時(shí)響應(yīng)變化示例

    vue.js實(shí)現(xiàn)輸入框輸入值內(nèi)容實(shí)時(shí)響應(yīng)變化示例

    這篇文章主要介紹了vue.js實(shí)現(xiàn)輸入框輸入值內(nèi)容實(shí)時(shí)響應(yīng)變化,結(jié)合實(shí)例形式分析了vue.js使用v-model屬性進(jìn)行數(shù)據(jù)綁定的相關(guān)操作技巧,需要的朋友可以參考下
    2018-07-07
  • Pytorch 計(jì)算誤判率,計(jì)算準(zhǔn)確率,計(jì)算召回率的例子

    Pytorch 計(jì)算誤判率,計(jì)算準(zhǔn)確率,計(jì)算召回率的例子

    今天小編就為大家分享一篇Pytorch 計(jì)算誤判率,計(jì)算準(zhǔn)確率,計(jì)算召回率的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-01-01
  • Python批量修改文件名操作指南(文件名的替換、前綴、后綴的添加)

    Python批量修改文件名操作指南(文件名的替換、前綴、后綴的添加)

    很多時(shí)候我們手上有一堆文件,需要修改名稱時(shí)需要一個(gè)一個(gè)修改,太麻煩了,這篇文章主要給大家介紹了關(guān)于Python批量修改文件名的相關(guān)資料,包括文件名的替換、前綴、后綴的添加的相關(guān)資料,需要的朋友可以參考下
    2024-04-04
  • Python yield生成器和return對(duì)比代碼實(shí)例

    Python yield生成器和return對(duì)比代碼實(shí)例

    這篇文章主要介紹了Python yield生成器和return對(duì)比代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 詳解Python中math和decimal模塊的解析與實(shí)踐

    詳解Python中math和decimal模塊的解析與實(shí)踐

    在Python中,math?和?decimal?模塊是處理數(shù)學(xué)運(yùn)算的重要工具,本文將深入探討這兩個(gè)模塊的基礎(chǔ)知識(shí),并通過(guò)實(shí)際的代碼示例演示它們的用法,希望對(duì)大家有所幫助
    2024-02-02
  • Python3.7中安裝openCV庫(kù)的方法

    Python3.7中安裝openCV庫(kù)的方法

    這篇文章主要介紹了Python3.7中安裝openCV庫(kù)的方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-07-07
  • python開(kāi)發(fā)的自動(dòng)化運(yùn)維工具ansible詳解

    python開(kāi)發(fā)的自動(dòng)化運(yùn)維工具ansible詳解

    ansible是新出現(xiàn)的自動(dòng)化運(yùn)維工具,基于Python開(kāi)發(fā),集合了眾多運(yùn)維工具(puppet、chef、func、fabric)的優(yōu)點(diǎn),實(shí)現(xiàn)了批量系統(tǒng)配置、批量程序部署、批量運(yùn)行命令等功能,這篇文章主要介紹了python開(kāi)發(fā)的自動(dòng)化運(yùn)維工具ansible詳解,需要的朋友可以參考下
    2021-08-08
  • Python報(bào)錯(cuò)NameError: name ‘secrets‘ is not defined解決

    Python報(bào)錯(cuò)NameError: name ‘secrets‘ is not

    在使用Python進(jìn)行安全編程時(shí),我們經(jīng)常需要使用secrets模塊來(lái)生成安全的隨機(jī)數(shù),但是卻遇到這個(gè)問(wèn)題,本文主要介紹了Python報(bào)錯(cuò)NameError: name ‘secrets‘ is not defined解決,感興趣的可以了解一下
    2024-06-06

最新評(píng)論