欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python 實(shí)現(xiàn)文件讀寫、坐標(biāo)尋址、查找替換功能

 更新時(shí)間:2019年09月11日 09:28:24   作者:呆呆象呆呆  
這篇文章主要介紹了Python 實(shí)現(xiàn)文件讀寫、坐標(biāo)尋址、查找替換功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下

讀文件

打開文件(文件需要存在)

#打開文件
f = open("data.txt","r")  #設(shè)置文件對象
print(f)#文件句柄
f.close() #關(guān)閉文件
#為了方便,避免忘記close掉這個文件對象,可以用下面這種方式替代
with open('data.txt',"r") as f:  #設(shè)置文件對象
  str = f.read()  #可以是隨便對文件的操作

完全讀取文件

#完全讀取文件
f = open("data.txt","r")  #設(shè)置文件對象
string1 = f.read()   #將txt文件的所有內(nèi)容讀入到字符串string1中
f.close()  #將文件關(guān)閉
print(string1)

按按行讀取整個文件方法一(刪除回車)

#按行讀取整個文件方法一(刪除回車)
data = []
f = open("data.txt","r")  #設(shè)置文件對象
line = f.readline()
if line !='\n' and line[len(line) -1 if len(line)-1>0 else 0] == "\n":#去掉換行符,也可以不去
  line_ = line[:-1]
data.append(line_)
while line:       #直到讀取完文件
  line = f.readline() #讀取一行文件,包括換行符
  if line !='' and line[len(line) -1 if len(line)-1>0 else 0] == "\n":#去掉換行符,也可以不去
    line_ = line[:-1]
    data.append(line_)
f.close() #關(guān)閉文件
print(data)

按行讀取整個文件方法一(不刪除回車)

#按行讀取整個文件方法一(不刪除回車)
data = []
f = open("data.txt","r")  #設(shè)置文件對象
line = f.readline()
data.append(line)
while line:       #直到讀取完文件
  line = f.readline() #讀取一行文件,包括換行符
  if line !='':
    data.append(line)
f.close() #關(guān)閉文件
print(data)

按行讀取整個文件第二種方法

#按行讀取整個文件第二種方法
data = []
for line in open("data.txt","r"): #設(shè)置文件對象并讀取每一行文件
  data.append(line)        #將每一行文件加入到list中
print(data )

按行讀取整個文件第三種方法

f = open("data.txt","r")  #設(shè)置文件對象
data = f.readlines() #直接將文件中按行讀到list里,效果與方法2一樣
f.close()       #關(guān)閉文件
print(data)

將文件讀入numpy數(shù)組中

#將文件讀入數(shù)組中
import numpy as np
data = np.loadtxt("data.txt")  #將文件中數(shù)據(jù)加載到data數(shù)組里
print(data)

寫文件列表寫入文件

#列表寫入文件(直接)
data = ['a','b','c']


#單層列表寫入文件
with open("data.txt","w") as f:
  f.writelines(data)

#列表寫入文件(加入一些東西)  
data = ['a','b','c']
#單層列表寫入文件
with open("data.txt","w") as f:
  for i in data:
    f.write(i+'\r\n')

 #二維列表寫入文件    
data =[ ['a','b','c'],['a','b','c'],['a','b','c']]
with open("data.txt","w") as f:                          #設(shè)置文件對象
  for i in data:
    i = str(i).strip('[').strip(']').replace(',','').replace('\'','').replace(' ',',')+'\r\n' #將其中每一個列表規(guī)范化成字符串
    print(i)
    f.write(i)  

#第二種方法,直接將每一項(xiàng)都寫入文件
data =[ ['a','b','c'],['a','b','c'],['a','b','c']]
with open("data.txt","w") as f:                          #設(shè)置文件對象
  for i in data:                                 #對于雙層列表中的數(shù)據(jù)
    f.writelines(i) 
   
#將數(shù)組寫入文件

import numpy as np
data =[ [1,2,3],[4,5,6],[7,8,9]]
# 第一種方法將數(shù)組中數(shù)據(jù)寫入到data.txt文件
np.savetxt("data1.txt",data) 
# 第二種方法將數(shù)組中數(shù)據(jù)寫入到data.npy文件
np.save("data",data)   
import numpy as np
filename = 'data.txt' # txt文件和當(dāng)前腳本在同一目錄下,所以不用寫具體路徑
dataele_list = []
with open(filename, 'r') as f:
  while True:
    lines = f.readline() # 整行讀取數(shù)據(jù)
    if not lines:
      break
    dataele_tmp = [float(i) for i in lines.split()] # 將整行數(shù)據(jù)分割處理,如果分割符是空格,括號里就不用傳入?yún)?shù),如果是逗號, 則傳入‘,'字符。
    dataele_list.append(dataele_tmp) # 添加新讀取的數(shù)據(jù)
dataele_np = np.array(dataele_list) # 將數(shù)據(jù)從list類型轉(zhuǎn)換為array類型。
print(dataele_np)

非替換寫入

#非替換寫入
#r+ 模式的指針默認(rèn)是在文件的開頭
# 如果直接寫入,則會覆蓋源文件,通過read() 讀取文件后,指針會移到文件的末尾,再寫入數(shù)據(jù)就不會有問題了。
# 這里也可以使用a 模式
f2 = open('data.txt','r+')
f2.read()
f2.write('\r\nhello boy!')
f2.close()
#非替換寫入
f2 = open('data.txt','a')
f2.write('\r\nhello fff!')
f2.close()

文件坐標(biāo)插入讀取

# 在開始使用open打開文件時(shí)候,將打開方式從r,換成rb即可 才可以使用seek移動
f = open('data.txt','rb')  
#f.tell()  #獲取指針位置

print("初始位置",f.tell())
# 開頭位置偏離3位置
f.seek(3,0)
print("開頭位置偏離3位置",f.tell())
print("==",f.readline(),"==")
print("讀取一行后位置",f.tell())
# 當(dāng)前位置偏離5位置
f.seek(5,1)
print("當(dāng)前位置偏離5位置",f.tell())
print("==",f.readline(),"==")
print("讀取一行后位置",f.tell())
# 結(jié)尾偏離5位置
f = open('data.txt','rb')
f.seek(0,2)
print("結(jié)尾偏離0位置",f.tell())
print("==",f.readline(),"==")
print("讀取一行后位置",f.tell())
f.seek(3,2)
print("結(jié)尾偏離3位置",f.tell())
print("==",f.readline(),"==")
print("讀取一行后位置",f.tell())

內(nèi)容查找

# 內(nèi)容查找
import re
f = open('data.txt')
source = f.read()
f.close()
r = 'www'
s = len(re.findall(r,source))
print(s)
import re
f = open("data.txt",'r')
count = 0
for s in f.readlines():
  li = re.findall("www",s)
  if len(li)>0:
    count = count + len(li)
print ("Search",count, "www")
f.close()

替換

#替換
f1 = open('data.txt','r')
f2 = open('data2.txt','w')
for s in f1.readlines():
  f2.write(s.replace('www','w')+'\r\n')
f1.close()
f2.close()

#排序 去除空行 注釋
f = open('data.txt')
result = list()
for line in f.readlines():        # 逐行讀取數(shù)據(jù)
  line = line.strip()        #去掉每行頭尾空白
  if not len(line) or line.startswith('#'):  # 判斷是否是空行或注釋行
    continue         #是的話,跳過不處理
  result.append(line)       #保存
f.close()
result.sort()            #排序結(jié)果
print(result)
f = open('data2.txt','w')
for line in result:
  f.write(line+'\r\n')

總結(jié)

以上所述是小編給大家介紹的Python 實(shí)現(xiàn)文件讀寫、坐標(biāo)尋址、查找替換功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • Python?讀取?Word?文檔操作

    Python?讀取?Word?文檔操作

    這篇文章主要介紹了Python讀取Word文檔操作,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • python bluetooth藍(lán)牙信息獲取藍(lán)牙設(shè)備類型的方法

    python bluetooth藍(lán)牙信息獲取藍(lán)牙設(shè)備類型的方法

    這篇文章主要介紹了python bluetooth藍(lán)牙信息獲取藍(lán)牙設(shè)備類型的方法,具體轉(zhuǎn)化方法文中給大家介紹的非常詳細(xì),非常不錯,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-11-11
  • Python中的choice()方法使用詳解

    Python中的choice()方法使用詳解

    這篇文章主要介紹了Python中的choice()方法使用詳解,是Python入門中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-05-05
  • Python OpenCV學(xué)習(xí)之特征點(diǎn)檢測與匹配詳解

    Python OpenCV學(xué)習(xí)之特征點(diǎn)檢測與匹配詳解

    提取圖像的特征點(diǎn)是圖像領(lǐng)域中的關(guān)鍵任務(wù),不管在傳統(tǒng)還是在深度學(xué)習(xí)的領(lǐng)域中,特征代表著圖像的信息,對于分類、檢測任務(wù)都是至關(guān)重要的。這篇文章主要為大家詳細(xì)介紹了OpenCV特征點(diǎn)檢測與匹配,需要的可以參考一下
    2022-01-01
  • selenium環(huán)境搭建及基本元素定位方式詳解

    selenium環(huán)境搭建及基本元素定位方式詳解

    selenium最初是一個自動化測試工具,而爬蟲中使用它主要是為了解決requests無法執(zhí)行javaScript代碼的問題,這篇文章主要介紹了selenium環(huán)境搭建及基本元素定位方式,需要的朋友可以參考下
    2023-04-04
  • Python 將 QQ 好友頭像生成祝福語的實(shí)現(xiàn)代碼

    Python 將 QQ 好友頭像生成祝福語的實(shí)現(xiàn)代碼

    這篇文章主要介紹了用 Python 將 QQ 好友頭像生成祝福語的實(shí)現(xiàn)代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • Python使用monkey.patch_all()解決協(xié)程阻塞問題

    Python使用monkey.patch_all()解決協(xié)程阻塞問題

    這篇文章主要介紹了Python使用monkey.patch_all()解決協(xié)程阻塞問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • python實(shí)現(xiàn)在無須過多援引的情況下創(chuàng)建字典的方法

    python實(shí)現(xiàn)在無須過多援引的情況下創(chuàng)建字典的方法

    這篇文章主要介紹了python實(shí)現(xiàn)在無須過多援引的情況下創(chuàng)建字典的方法,是非常實(shí)用的技巧,需要的朋友可以參考下
    2014-09-09
  • Python實(shí)現(xiàn)的大數(shù)據(jù)分析操作系統(tǒng)日志功能示例

    Python實(shí)現(xiàn)的大數(shù)據(jù)分析操作系統(tǒng)日志功能示例

    這篇文章主要介紹了Python實(shí)現(xiàn)的大數(shù)據(jù)分析操作系統(tǒng)日志功能,涉及Python大文件切分、讀取、多線程操作等相關(guān)使用技巧,需要的朋友可以參考下
    2019-02-02
  • Python實(shí)現(xiàn)全自動安裝第三方庫的方法

    Python實(shí)現(xiàn)全自動安裝第三方庫的方法

    這篇文章主要介紹了Python實(shí)現(xiàn)全自動安裝第三方庫的方法,一說Python要安裝哪個模塊,我們第一反應(yīng),win+r輸入cmd,pip?instll安裝,但是如果換電腦了,Python第三方庫那么多,難道要一次一次的敲擊pip?install,本文就介紹一個簡單的方法解放雙手,需要的朋友可以參考下
    2023-07-07

最新評論