1. 程式人生 > >Python csv模組的使用

Python csv模組的使用

1、csv簡介

格式,用以儲存表格資料,包括數字或者字元。很多程式在處理資料時都會碰到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物件指定的編碼風格。

  1. import csv  
  2. with open('test.csv','rb') as myFile:  
  3.     lines=csv.reader(myFile)  
  4.     for line in lines:  
  5.         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)

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

  1. with open('t.csv','wb') as myFile:      
  2.     myWriter=csv.writer(myFile)  
  3.     myWriter.writerow([7,'g'])  
  4.     myWriter.writerow([8,'h'])  
  5.     myList=[[1,2,3],[4,5,6]]  
  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、

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

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

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

在我test.csv中儲存如下資料:

以'mydialect'風格列印:

  1. with open('test.csv','rb') as myFile:  
  2.     lines=csv.reader(myFile,'mydialect')  
  3.     print lines.line_num  
  4.     for line in lines:  
  5.         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:

  1. 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模組讀取基本操作

csv即逗號分隔值,可用Excel開啟 1.向csv檔案中寫入資料 (1)列表方式的寫入 import csv with open('data.csv','a+',encoding='utf-8',newline='') as csvfile: writer = csv.writer(c

Python csv模組的使用

1、csv簡介 格式,用以儲存表格資料,包括數字或者字元。很多程式在處理資料時都會碰到csv這種格式的檔案,它的使用是比 較廣泛的(Kaggle上一些題目提供的資料就是csv格式),csv雖然使用廣泛,但卻沒有通用的標準,所以在處理csv 格式時常常會碰到麻煩,幸好

Python csv模組學習

Introduce CSV (Cmma-Separated Values)是逗號分隔值(也稱字元分隔值,因為分隔符可以不是逗號)的簡寫。是一種常用的文字格式,用以儲存表格資料,包括數字或者字元。 純文字意味著該檔案是一個字元序列,不含必須像二進位制數字那樣被

python CSV模組使用筆記

import csv csv.reader: reader(csvfile[, dialect=’excel’][, fmtparam]) reader = csv.reader(fil

python csv模組使用

csv 模組 什麼是csv和xslx 有什麼區別 csv是最通用的一種檔案格式,它可以非常容易地被匯入各種PC表格及資料庫中。 此檔案,一行即為資料表的一行。生成資料表字段用半形逗號隔開。 csv是文字檔案,用記事本就能開啟,XLS是二進位制的檔案只有

python csv模組配置分隔符和引用符

file = open('./abc.csv') csv.reader(file, delimiter=',', quotechar='"') 說明:delimiter是分隔符,quotechar是引

python csv模組寫檔案 出現 iterable expected, not int 錯誤

開始程式碼: import csv def storFile(data,fileName): with open(fileName,'w',newline ='') as f:

python csv模組使用例項

在進行Python編碼過程中,有時候需要用到部分的通用資料,可以通過讀取csv檔案的資料來實現,以下是一個讀取本地csv檔案資料,並將每一個表格對應的資料儲存到列表中,後續可以通過呼叫列表來使用該資料: #!/usr/bin/python # -*- coding: utf

Python內建包】csv模組用法

一、概述 CSV(逗號分隔符)檔案是表格與資料庫操作之中最常用的輸入輸出格式。在RFC4180中的檔案描述標準對CSV格式進行規範之前,CSV格式檔案就已經被應用了很多年了。而缺乏合適的格式描述規範意味著不同應用的輸入輸出格式會有著細微的差別。因此在從不同源生成這些檔案的時候,這些差別相

Python中的CSV模組基本用法

CSV模組提供一種非常便捷的方式操作CSV檔案。本文只是展現最基本的csv檔案的讀寫操作,因為使用的是Python2.7 所以open接受引數少,整個csv讀寫例子如下 import csv fname = 'testcsv.csv' with open(fname,'wb') as

pythoncsv模組用法(詳細)tcy

python csv模組  2018/12/23 # CSV以純文字儲存數和文字。檔案的每一行就代表一條資料,每條記錄包含由逗號分隔一個或多個屬性值。  1.說明: 1) 預設讀寫用逗號做分隔符(delimiter),雙引號作引用符(quotechar) 2) 用wri

python讀取、寫入csv資料:csv模組

通過csv模組可以輕鬆讀取格式為csv的檔案,而且csv模組是python內建的,不需要下載就可以直接用。 一、準備csv檔案 檔名是 e:\t.csv,檔案內容: org_id,org_name

Pythoncsv模組的使用

Python csv模組的使用 1、csv簡介 格式,用以儲存表格資料,包括數字或者字元。很多程式在處理資料時都會碰到csv這種格式的檔案,它的使用是比 較廣泛的(Kaggle上一些題目提供的資料就是csv格式),csv雖然使用廣泛,但卻沒有通用的標準,所以在處理csv

Python re json csv模組

re模組下常用函式 find_all函式 滿足條件的所有元組 sub函式 替換 spkit函式 以什麼為分隔符,轉換成列表 compile函式 編譯正則表示式 方便後續呼叫 可以用""" “”"的格式編寫 zip函式 第一項與第一項關聯組

pythonCSV模組

開發環境:Python 3.4.3 (v3.4.3:9b73f1c3e601, Feb 24 2015, 22:44:40) [MSC v.1600 64 bit (AMD64)] on win32 自序 也許你會說,我為什麼要學習使用CSV模組呢?沒有CSV模組我一樣可以解析操作CSV檔案,比如下面這種

csv模組學習:Python學習筆記—CSV模組讀寫資料

CSV模組是Python的內建模組,直接import csv就可呼叫。csv模組主要就兩個函式:csv.reader()——讀取csv檔案資料,csv.writer()——寫入csv檔案資料。簡單實用。 一、讀取CSV 語法:csv.reader(iterable[,

python csv文件打開錯誤:_csv.Error: line contains NULL byte

sum print question utf-16 null ecs 格式 .cn repl 正常的csv文件讀取如下: #coding:utf-8 import csv csvfilename = ‘demo.csv‘ print u‘########

Python csv.md

star relative numeric 舉例 padding comment cell itl dna csv csv模塊可以用於處理從電子表格和數據庫導出的數據到帶有字段和記錄格式的文本文件,通常稱為逗號分隔值(csv)格式,因為逗號通常用於分隔記錄中的

python csv 模塊reader後轉換為列表

ble app try proto which -m 實現 all supports fh = open("mylist_wincsv.csv", ‘rt‘) reader = csv.reader(fh) data = list(reade

python csv模塊

dia 轉義 char writer limit bsp names min fields 1 import csv # Comma Separated Value 2 3 # class Dialect 4 # delimiter = Non