国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python CSV模塊使用實例

Python CSV模塊使用實例

2020-06-02 10:04腳本之家 Python

這篇文章主要介紹了Python CSV模塊使用實例,本文將舉幾個例子來介紹一下Python的CSV模塊的使用方法,包括reader、writer、DictReader、DictWriter.register_dialect等,需要的朋友可以參考下

舉幾個例子來介紹一下,Python 的 CSV模塊的使用方法,包括,reader, writer, DictReader, DictWriter.register_dialect

一直非常喜歡python的csv模塊,簡單易用,經常在項目中使用,現在舉幾個例子說明一下。

復制代碼 代碼如下:

reader(csvfile[, dialect='excel'][, fmtparam])


參數表:

 

csvfile
        需要是支持迭代(Iterator)的對象,并且每次調用next方法的返回值是字符串(string),通常的文件(file)對象,或者列表(list)對象都是適用的,如果是文件對象,打開是需要加"b"標志參數。

dialect
        編碼風格,默認為excel方式,也就是逗號(,)分隔,另外csv模塊也支持excel-tab風格,也就是制表符(tab)分隔。其它的方式需要自己定義,然后可以調用register_dialect方法來注冊,以及list_dialects方法來查詢已注冊的所有編碼風格列表。

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

例子:

復制代碼 代碼如下:


import csv

 

reader = csv.reader(file('your.csv', 'rb'))
for line in reader:
    print line
 

writer(csvfile[, dialect='excel'][, fmtparam])


參數表(略: 同reader, 見上)

 

例子:

復制代碼 代碼如下:


import csv

 

writer = csv.writer(file('your.csv', 'wb'))
writer.writerow(['Column1', 'Column2', 'Column3'])
lines = [range(3) for i in range(5)]
for line in lines:
    writer.writerow(line)

 

DictReader

同reader差不多,都是讀取CSV用的,只不過會生成一個字典(dict)類型的返回,而不是迭代類型。

DictWriter

 我主要想說的是DictWriter,我為什么會喜歡使用DictWriter呢,因為普通的writer你需要手工去構建列表,尤其是通過表單提交的時候,而我之前因為一直在zope平臺上開發,而zope支持一種高級表單數據模型,也就是可以通過定義表單的時候加入相應的標志來使提交后的表單數據自動的生成一個記錄(records)類型,也就是生成一個每項數據都是一個字典的列表。這樣,我就可以非常方便的直接把表單數據傳給 DictWriter而生成csv,當然這個是在你能保證數據的正確性的前提下。好下面我來簡單的說明一下這種zope的高級表單數據類型。

例子:

復制代碼 代碼如下:

<form action='test_form_action' method=post>
            <input type="text" name="rows.Column1:records" value="0" />
            <input type="text" name="rows.Column2:records" value="1" />
            <input type="text" name="rows.Column3:records" value="2" />
            <input type="text" name="rows.Column4:records" value="3" />
    <br />
            <input type="text" name="rows.Column1:records" value="0" />
            <input type="text" name="rows.Column2:records" value="1" />
            <input type="text" name="rows.Column3:records" value="2" />
            <input type="text" name="rows.Column4:records" value="3" />
    <br />
            <input type="text" name="rows.Column1:records" value="0" />
            <input type="text" name="rows.Column2:records" value="1" />
            <input type="text" name="rows.Column3:records" value="2" />
            <input type="text" name="rows.Column4:records" value="3" />
    <br />
            <input type="text" name="rows.Column1:records" value="0" />
            <input type="text" name="rows.Column2:records" value="1" />
            <input type="text" name="rows.Column3:records" value="2" />
            <input type="text" name="rows.Column4:records" value="3" />
    <br />
            <input type="text" name="rows.Column1:records" value="0" />
            <input type="text" name="rows.Column2:records" value="1" />
            <input type="text" name="rows.Column3:records" value="2" />
            <input type="text" name="rows.Column4:records" value="3" />
    <br />
<input type="submit" value="Submit CSV" />
</form>


表單提交后的結果是:

復制代碼 代碼如下:

rows = [{'Column1': '0', 'Column2': '1', 'Column3': '2', 'Column4': '3'},
        {'Column1': '0', 'Column2': '1', 'Column3': '2', 'Column4': '3'},
        {'Column1': '0', 'Column2': '1', 'Column3': '2', 'Column4': '3'},
        {'Column1': '0', 'Column2': '1', 'Column3': '2', 'Column4': '3'},
        {'Column1': '0', 'Column2': '1', 'Column3': '2', 'Column4': '3'}]


這樣就可以直接調用DictWriter.writerows方法來處理了:

復制代碼 代碼如下:


import csv

 

fieldnames = ['Column1', 'Column2', 'Column3', 'Column4']
dict_writer = csv.DictWriter(file('your.csv', 'wb'), fieldnames=fieldnames)
dict_writer.writerow(fieldnames) # CSV第一行需要自己加入
dict_writer.writerows(rows)  # rows就是表單提交的數據

*注意:這里的csv文件寫入需要External Method的支持,因為在zope中由于權限沙箱的問題是不能直接操作csv模塊來讀寫文件系統的。


 
這樣用起來是不是非常的方便呢,這里給出生成上面表單的DTML代碼:

復制代碼 代碼如下:

<form action='test_form' method=post>
<dtml-in "range(5)">
    <dtml-in "range(4)">
        <input type="text" name="rows.Column&dtml-sequence-number;:records" value="&dtml-sequence-item;" />
    </dtml-in>
<br />
</dtml-in>
<input type="submit" value="Submit CSV" />
</form>


您可以根據您自己的需要來改寫這個表單的生成。

 

參考文獻:
http://docs.python.org/lib/module-csv.html
http://www.python.org/dev/peps/pep-0305/

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品伦一区二区三级视频 | 亚洲精品视频在线 | 日韩成人一级 | 色婷婷精品久久二区二区蜜臂av | 亚洲欧美日韩在线一区 | 成年人在线观看免费视频 | 99精品网站| av香蕉| 亚洲视频在线免费观看 | 日韩福利电影 | 亚洲一级黄色 | 在线视频三级 | 青娱乐自拍偷拍 | 久久黄网站 | 7799精品视频 | 91精品麻豆日日躁夜夜躁 | 中文字幕一二三区 | 国产成人免费在线 | 亚洲精品区 | 欧美电影网站 | 在线观看成人小视频 | 欧美成人激情视频 | 欧美freesex| 精品成人av一区二区三区 | 成人黄色免费 | 在线观看一区 | 九九九九国产 | 久久91精品 | 免费一区在线观看 | 日韩激情一区二区三区 | 一区二区精品在线 | 欧美日韩中文 | 国产亚洲一区二区精品 | 亚洲午夜在线 | 精品天堂 | 97精品国产97久久久久久粉红 | 日本成人一区 | 黄色片网站在线免费观看 | 蜜桃av一区二区三区 | 亚洲精品1区2区 | 久久精品亚洲精品国产欧美 |