Python 如何實(shí)時(shí)向文件寫入數(shù)據(jù)(附代碼)
之前在做數(shù)據(jù)分析的過程中,需要對數(shù)據(jù)進(jìn)行實(shí)時(shí)的寫入,比如對新生成的數(shù)據(jù)寫入之前已經(jīng)生成的txt或csv文件中?,F(xiàn)在想想其實(shí)很簡單,所以做一個(gè)總結(jié)。
1:實(shí)時(shí)向csv文件寫入數(shù)據(jù)
假設(shè)需要生成一張csv表,里面的字段對應(yīng)一些數(shù)據(jù),由于后續(xù)的過程中,不止一次寫入數(shù)據(jù),那么安全的做法是:
- 首先寫入字段;
- 然后寫入數(shù)據(jù)(否則字段也會(huì)每次被寫入)
步驟1:創(chuàng)建文件并寫入字段
import csv with open("test3.csv","a",newline='') as csvfile: writer = csv.writer(csvfile, delimiter=' ') writer.writerow(["index","a_name","b_name"])
上述代碼參數(shù)解釋:
? test3.csv
表示要?jiǎng)?chuàng)建一個(gè)test3.csv的文件,注意:如果當(dāng)前目錄下沒有這個(gè)文件,則會(huì)自動(dòng)生成test3.csv文件,如果當(dāng)前目錄下已經(jīng)有了test3.csv的文件,那么在新建結(jié)束后,會(huì)將原始的test3.csv文件覆蓋。? "a"
表示導(dǎo)入的數(shù)據(jù)不會(huì)講test3.csv文件中的原始數(shù)據(jù)覆蓋,即:在后面繼續(xù)添加,如果需要覆蓋,則將"a"改成"w"即可。- ?
newline=’ ’
表示不會(huì)以空行作為每一行的分割線,注意:這一行代碼必須添加上,否則csv文件中的每一行數(shù)據(jù)的前面會(huì)出現(xiàn)空行。
步驟2:寫入數(shù)據(jù)
list1=[0,0,0] list2=[1,1,1] data_array=[[5,5,5],[1,2,3]] with open("test3.csv","a",newline='') as csvfile: writer = csv.writer(csvfile) # 多行寫入用writerows writer.writerows(data_array) # 單行逐個(gè)寫入用 writerow # writer.writerow(list1) # writer.writerow(list2) # 執(zhí)行添加數(shù)據(jù)操作之后,要寫close關(guān)閉,否則下次無法再次插入新的數(shù)據(jù) csvfile.close()
實(shí)時(shí)寫入數(shù)據(jù)時(shí),有可能是逐個(gè)寫入,也可能是一次性寫入多個(gè)數(shù)據(jù)。多行寫入用writerows,
單行逐個(gè)寫入用 writerow,根據(jù)需求調(diào)整。close()這行代碼一定要加上,否則下次無法再次插入新的數(shù)據(jù)。
運(yùn)行結(jié)果:
再次逐個(gè)寫入,代碼:
list1=[0,0,0] list2=[1,1,1] data_array=[[5,5,5],[1,2,3]] with open("test3.csv","a",newline='') as csvfile: writer = csv.writer(csvfile) # 寫入多行用writerows # writer.writerows(data_array) # 寫入單行用 writerow writer.writerow(list1) writer.writerow(list2) # 執(zhí)行添加數(shù)據(jù)操作之后,要寫close關(guān)閉,否則下次無法再次插入新的數(shù)據(jù) csvfile.close()
運(yùn)行結(jié)果:
結(jié)果顯示,逐個(gè)添加數(shù)據(jù)成功。
注意的地方
如果不是逐行寫入,而是直接將數(shù)組一次性寫入到csv文件中(相當(dāng)于多行寫入),則上述代碼中改用writerows即可
2:實(shí)時(shí)向txt文件寫入數(shù)據(jù)
實(shí)時(shí)向txt文件寫入內(nèi)容的過程,與創(chuàng)建csv文件,實(shí)時(shí)向文件寫入內(nèi)容大致相同,只需要添加一個(gè)換行符就行。
代碼:
with open ('testing.txt','a') as f: f.write('%s %s %s'%('姓名','國籍','金額'))
運(yùn)行結(jié)果:
結(jié)果生成了一個(gè)testing.txt的文件。
再次向txt文件中寫入數(shù)據(jù)
代碼:
with open ('testing.txt','a') as f: f.write('\n') #換行 f.write('%s %s %d' %('張三','中國',2000))
運(yùn)行結(jié)果:
結(jié)果顯示,已經(jīng)將數(shù)據(jù)寫入txt文件中。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
超詳細(xì),教你用python語言實(shí)現(xiàn)QQ機(jī)器人制作教程
這篇文章主要介紹了如何python語言實(shí)現(xiàn)QQ機(jī)器人,用圖文詳細(xì)的描述了其中的操作步驟,非常的簡單易上手,有需要的朋友可以參考下2021-08-08Python使用pymupdf實(shí)現(xiàn)PDF內(nèi)容搜索并顯示功能
在日常工作和學(xué)習(xí)中,我們可能需要查找和提取PDF文件中的特定內(nèi)容,本文將介紹如何使用pymupdf實(shí)現(xiàn)PDF內(nèi)容搜索并顯示的功能,需要的可以參考下2023-08-08python調(diào)用短信貓控件實(shí)現(xiàn)發(fā)短信功能實(shí)例
這篇文章主要介紹了python調(diào)用短信貓控件實(shí)現(xiàn)發(fā)短信功能實(shí)例,需要的朋友可以參考下2014-07-07簡單了解Python下用于監(jiān)視文件系統(tǒng)的pyinotify包
這篇文章主要介紹了Python下用于監(jiān)視文件系統(tǒng)的pyinotify包,pyinotify基于inotify事件驅(qū)動(dòng)機(jī)制,需要的朋友可以參考下2015-11-11Python對接六大主流數(shù)據(jù)庫(只需三步)
這篇文章主要介紹了Python對接六大主流數(shù)據(jù)庫(只需三步),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07使用py2exe在Windows下將Python程序轉(zhuǎn)為exe文件
這篇文章主要介紹了Windows下用py2exe將Python程序轉(zhuǎn)為exe文件的方法,注意py2exe只是負(fù)責(zé)文件格式的轉(zhuǎn)換,并不能將Python程序編譯為機(jī)器碼,要的朋友可以參考下2016-03-03Python中條件語句、循環(huán)語句和pass語句的使用示例
Python條件語句是通過一條或多條語句的執(zhí)行結(jié)果(True或者False)來決定執(zhí)行的代碼塊,下面這篇文章主要給大家介紹了關(guān)于Python中條件語句、循環(huán)語句和pass語句使用的相關(guān)資料,需要的朋友可以參考下2022-06-06