seek引發(fā)的python文件讀寫的問題及解決
我的需求很簡單,就是統(tǒng)計一下我的安裝腳本執(zhí)行的次數(shù)和時間,格式是這樣的
install_times:1|install_times:2018-09-03 15:58:46 install_times:2|install_times:2018-09-03 15:58:50 install_times:3|install_times:2018-09-03 15:58:54
首先我需要判斷一下文件是否為空,我開始是這樣寫的
import time import os file_list = [] tags = False with open("install_hadoop.txt", "r", encoding="utf-8") as f: flag = bool(f.readline()) # obj = True # f.seek(0) if flag: tags = True for obj in f: tmp_list = obj.split("|") file_list.append(tmp_list) last_times = int(file_list[-1][0].split(":")[1]) + 1 last_time = time.strftime("%Y-%m-%d %H:%M:%S") else: last_times = 1 last_time = time.strftime("%Y-%m-%d %H:%M:%S")
先通過f.readline()讀一行文件出來,判斷返回的對象是否為真,如果為真,則認(rèn)為文件不為空,則繼續(xù)往下走,這里有個問題就是,當(dāng)我讀出來一行后,我的指針的位置到了第一行的末尾,等下在去讀文件,直接從第二行去讀數(shù)據(jù),本來我這里是要讀到所有的數(shù)據(jù),但是由于seek導(dǎo)致我的數(shù)據(jù)是從第二行開始的,所以得出來的結(jié)果就不對
這里可以有2種辦法解決
1、通過f.readline()讀一次文件之后,在f.seek(0),把指針在設(shè)置回到最開始的位置
with open("install_hadoop.txt", "r", encoding="utf-8") as f: flag = bool(f.readline()) # obj = True <strong> f.seek(0)</strong> if flag: tags = True for obj in f: tmp_list = obj.split("|") file_list.append(tmp_list) last_times = int(file_list[-1][0].split(":")[1]) + 1 last_time = time.strftime("%Y-%m-%d %H:%M:%S") else: last_times = 1 last_time = time.strftime("%Y-%m-%d %H:%M:%S")
2、修改判斷文件是否為空的方法,采用os.path.getsize的方法來判斷文件是否為空
with open("install_hadoop.txt", "r", encoding="utf-8") as f:<br> flag = bool(f.readline())<br> # obj = True<br> f.seek(0)<br> <strong>print(os.path.getsize("install_hadoop.txt"))</strong><br> if flag:<br> tags = True<br> for obj in f:<br> tmp_list = obj.split("|")<br> file_list.append(tmp_list)<br> last_times = int(file_list[-1][0].split(":")[1]) + 1<br> last_time = time.strftime("%Y-%m-%d %H:%M:%S")<br> else:<br> last_times = 1<br> last_time = time.strftime("%Y-%m-%d %H:%M:%S")
至此,這個問題被解決,同時也對python的文件操作有了更深的理解,也明白了python設(shè)置seek的作用
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python如何解析復(fù)雜sql,實現(xiàn)數(shù)據(jù)庫和表的提取的實例剖析
這篇文章主要介紹了python如何解析復(fù)雜sql,實現(xiàn)數(shù)據(jù)庫和表的提取的實例剖析,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05Python 關(guān)于模塊和加載模塊的實現(xiàn)
這篇文章主要介紹了Python 關(guān)于模塊和加載模塊的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03解決pycharm下載庫時出現(xiàn)Failed to install package的問題
很多小伙伴遇到pycharm下載庫時出現(xiàn)Failed to install package不知道怎么解決,下面小編給大家?guī)砹私鉀Q方法,需要的朋友參考下吧2021-09-09