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

python中內(nèi)置庫csv的使用及說明

 更新時間:2022年11月29日 16:31:47   作者:玉米叢里吃過虧  
這篇文章主要介紹了python中內(nèi)置庫csv的使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

所謂的CSV(逗號分隔值)格式是電子表格和數(shù)據(jù)庫最常用的導(dǎo)入和導(dǎo)出格式。

嘗試使用CSV格式進(jìn)行標(biāo)準(zhǔn)化描述之前已經(jīng)使用了很多年。

該csv模塊reader和writer對象讀取和寫入序列。

程序員還可以使用DictReader和DictWriter類以字典形式讀取和寫入數(shù)據(jù)。

讀取

reader(iterable, dialect=‘excel', *args, **kwargs)

該方法返回一個reader對象,該對象將遍歷給定的iterable中的行。默認(rèn)情況下,從csv文件中讀取的每一行都作為字符串列表返回,除非指定了quoting參數(shù)值為QUOTE_NONNUMERIC。如下:

假設(shè)有這么一個文件a.csv,內(nèi)容如下:

1,2,3,4
5,6,7,8
9,10,11,12

我們讀取一下這個csv

import csv

with open('a.csv') as f:
? ? reader = csv.reader(f)
? ? print(type(reader), reader)
? ? for item in reader:
? ? ? ? print(type(item), item)
? ? ? ??
############# 打印結(jié)果如下 #############
<class '_csv.reader'> <_csv.reader object at 0x000002194D601F50>
<class 'list'> ['1', '2', '3', '4']
<class 'list'> ['5', '6', '7', '8']
<class 'list'> ['9', '10', '11', '12']

當(dāng)我們設(shè)置quoting參數(shù)值為QUOTE_NONNUMERIC時:

with open('a.csv') as f:
? ? reader = csv.reader(f, quoting=csv.QUOTE_NONNUMERIC)
? ? print(type(reader), reader)
? ? for item in reader:
? ? ? ? print(type(item), item)
? ? ? ??
############# 打印結(jié)果如下 #############
<class '_csv.reader'> <_csv.reader object at 0x000002BFC3291F50>
<class 'list'> [1.0, 2.0, 3.0, 4.0]
<class 'list'> [5.0, 6.0, 7.0, 8.0]
<class 'list'> [9.0, 10.0, 11.0, 12.0]

更多參數(shù)解釋請看下面kwargs參數(shù)

DictReader(f, fieldnames=None, restkey=None, restval=None, dialect=“excel”, *args, **kwds)

創(chuàng)建一個DictReader對象,其功能類似于常規(guī)讀取器,但是將每行的信息映射到OrderDict當(dāng)中。

OrderDict的鍵名可由filednames參數(shù)指定,如果未指定,那么將由第一行數(shù)據(jù)作為鍵名;如果數(shù)據(jù)中的字段多于字段名列表,則剩余的數(shù)據(jù)以列表存儲起來,其健名由restkey指定(默認(rèn)為None);如果數(shù)據(jù)中的值少于字段名列表,則缺少的值將默認(rèn)填充為restval設(shè)定的值(默認(rèn)為None)。

with open('a.csv') as f:
? ? reader = csv.DictReader(f)
? ? print(type(reader), reader)
? ? for item in reader:
? ? ? ? print(type(item), item)

############# 打印結(jié)果如下 #############
<class 'csv.DictReader'> <csv.DictReader object at 0x000001F3EE9A8898>
<class 'collections.OrderedDict'> OrderedDict([('1', '5'), ('2', '6'), ('3', '7'), ('4', '8')])
<class 'collections.OrderedDict'> OrderedDict([('1', '9'), ('2', '10'), ('3', '11'), ('4', '12')])

設(shè)置了fieldnames情況下:

...
reader = csv.DictReader(f, fieldnames=['a', 'b', 'c', 'd'])
...

############# 打印結(jié)果如下 #############
<class 'csv.DictReader'> <csv.DictReader object at 0x00000249BED38898>
<class 'collections.OrderedDict'> OrderedDict([('a', '1'), ('b', '2'), ('c', '3'), ('d', '4')])
<class 'collections.OrderedDict'> OrderedDict([('a', '5'), ('b', '6'), ('c', '7'), ('d', '8')])
<class 'collections.OrderedDict'> OrderedDict([('a', '9'), ('b', '10'), ('c', '11'), ('d', '12')])

無論是reader對象還是DictReader對象,都具有如下操作:

  • __next__(): 將閱讀器可迭代對象的下一行作為列表或字典返回
  • dialect: 獲取閱讀器的dialect描述
  • line_num: 獲取閱讀器讀取的行數(shù)
  • fieldnames: 獲取鍵名(DictReader對象獨(dú)有)

更多參數(shù)解釋請看下面kwargs參數(shù)

寫入

writer(fileobj, dialect=‘excel', *args, **kwargs)

將用戶數(shù)據(jù)寫入到指定的文件對象上,返回一個writer對象

import csv

# 一定要指定newline='', 否則將會每行數(shù)據(jù)之間將會有空行
with open('b.csv', mode='w', newline='') as f:
? ? writer = csv.writer(f)
? ? writer.writerow([1, 2, 3, 4])
? ? writer.writerow([5, 6, 7, 8])

更多參數(shù)解釋請看下面kwargs參數(shù)

DictWriter(f, fieldnames, restval="", extrasaction=“raise”, dialect=“excel”, *args, **kwds)

將用戶數(shù)據(jù)寫入到指定文件對象上,但需指定fieldnames(鍵名),返回一個DictWriter對象。

如果數(shù)據(jù)中的值少于字段名列表,則缺少的值將默認(rèn)填充為restval設(shè)定的值(默認(rèn)為None)。

import csv

# 一定要指定newline='', 否則將會每行數(shù)據(jù)之間將會有空行
with open('b.csv', mode='w', newline='') as f:
? ? writer = csv.DictWriter(f, fieldnames=['a', 'b', 'c', 'd'])
? ? writer.writerow({'a': 1, 'b': 2, 'c': 3, 'd': 4})
? ? writer.writerow({'a': 5, 'b': 6, 'c': 7, 'd': 8})

值得注意的是,默認(rèn)情況下fieldnames數(shù)據(jù)并不會寫入到文件當(dāng)中!

無論是reader對象還是DictReader對象,都具有如下操作:

writerow(rowdict): 將行數(shù)據(jù)寫入到文件對象
writerows(rowdicts): 所有行數(shù)據(jù)寫入到文件對象當(dāng)中
import csv
with open('b.csv', mode='w', newline='') as f:
? ? writer = csv.writer(f)
? ? writer.writerows([[1, 2, 3, 4], [5, 6, 7, 8]])
  • dialect: 獲取寫入器的dialect描述
  • writeheader(): 用fieldnames數(shù)據(jù)寫入一行(DictWriter對象獨(dú)有)

更多參數(shù)解釋請看下面kwargs參數(shù)

kwargs參數(shù)

  • delimiter

一個用于分割字段的分隔符,默認(rèn)為,

  • lineterminator

行終止符,默認(rèn)為\r\n

  • quoting

控制何時引用應(yīng)該由作者產(chǎn)生并被讀者識別

  • skipinitialspace

如果設(shè)置為True,分割符后面的空白將被忽略。默認(rèn)為False

"""
假設(shè)a.csv的內(nèi)容如下
1, 2,3,4
"""

import csv
with open('a.csv') as f:
? ? reader = csv.reader(f)
? ? # reader = csv.reader(f, skipinitialspace=True)
? ? for item in reader:
? ? ? ? print(type(item), item)

############ 默認(rèn)情況,打印如下 ############
<class 'list'> ['1', ' 2', '3', '4']

############ skipinitialspace=True,打印如下 ############
<class 'list'> ['1', '2', '3', '4']
  • strict

如果設(shè)置為True,則將csv輸入錯誤時將引發(fā)異常。默認(rèn)為False

更多參數(shù)解釋以及csv模塊的使用,請看:https://docs.python.org/3.7/library/csv.html

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python求解任意閉區(qū)間的所有素數(shù)

    Python求解任意閉區(qū)間的所有素數(shù)

    本篇文章是一篇關(guān)于python求素數(shù)的知識點(diǎn)內(nèi)容,如果大家在應(yīng)用中有用的到,不妨跟著學(xué)習(xí)下。
    2018-06-06
  • Keras - GPU ID 和顯存占用設(shè)定步驟

    Keras - GPU ID 和顯存占用設(shè)定步驟

    這篇文章主要介紹了Keras - GPU ID 和顯存占用設(shè)定步驟,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • pycharm的python_stubs問題

    pycharm的python_stubs問題

    這篇文章主要介紹了pycharm的python_stubs問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • Python批量加密Excel文件的實(shí)現(xiàn)示例

    Python批量加密Excel文件的實(shí)現(xiàn)示例

    在日常工作中,保護(hù)敏感數(shù)據(jù)是至關(guān)重要的,本文主要介紹了Python批量加密Excel文件的實(shí)現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • 解決pyinstaller打包發(fā)布后的exe文件打開控制臺閃退的問題

    解決pyinstaller打包發(fā)布后的exe文件打開控制臺閃退的問題

    今天小編就為大家分享一篇解決pyinstaller打包發(fā)布后的exe文件打開控制臺閃退的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • Python入門教程(二十三)Python的繼承

    Python入門教程(二十三)Python的繼承

    這篇文章主要介紹了Python入門教程(二十三)Python的繼承,Python是一門非常強(qiáng)大好用的語言,也有著易上手的特性,本文為入門教程,需要的朋友可以參考下
    2023-04-04
  • python爬蟲MeterSphere平臺執(zhí)行報告使用實(shí)戰(zhàn)

    python爬蟲MeterSphere平臺執(zhí)行報告使用實(shí)戰(zhàn)

    這篇文章主要為大家介紹了python爬蟲MeterSphere平臺執(zhí)行報告使用實(shí)戰(zhàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • Python中22個萬用公式的小結(jié)

    Python中22個萬用公式的小結(jié)

    在大家的日常python程序的編寫過程中,都會有自己解決某個問題的解決辦法,或者是在程序的調(diào)試過程中,用來幫助調(diào)試的程序公式,本文總結(jié)了22個萬用公式,感興趣的可以了解一下
    2021-07-07
  • django rest framework 實(shí)現(xiàn)用戶登錄認(rèn)證詳解

    django rest framework 實(shí)現(xiàn)用戶登錄認(rèn)證詳解

    這篇文章主要介紹了django rest framework 實(shí)現(xiàn)用戶登錄認(rèn)證詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07
  • 利用機(jī)器學(xué)習(xí)預(yù)測房價

    利用機(jī)器學(xué)習(xí)預(yù)測房價

    這篇文章主要介紹了利用機(jī)器學(xué)習(xí)回歸模型預(yù)測房價,解釋清晰,代碼詳細(xì),是很不錯的機(jī)器學(xué)習(xí)實(shí)戰(zhàn)演練,對機(jī)器學(xué)習(xí)感興趣的朋友可以參考一下
    2021-04-04

最新評論