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

python腳本生成caffe train_list.txt的方法

 更新時(shí)間:2018年04月27日 10:45:59   作者:跬步達(dá)千里  
下面小編就為大家分享一篇python腳本生成caffe train_list.txt的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧

首先給出代碼:

import os
    
path = "/home/data//"
path_exp = os.path.expanduser(path)
classes = [int(p) for p in os.listdir(path_exp)]
classes.sort()
# nrof_classes一個(gè)數(shù)據(jù)集下有多少個(gè)文件夾,就是說有多少個(gè)人,多少個(gè)類別
nrof_classes = len(classes)
count=0
files = open("train_list.txt",'w')
filets = open("test_list.txt",'w')
count_u=0
for i in range(nrof_classes):
  class_name = str(classes[i])
  count=count+1
  count_u=count_u+1
  facedir = os.path.join(path_exp, class_name)
  prefix1 = path+class_name+"/"

  if os.path.isdir(facedir):
    images = os.listdir(facedir)
    #print(images[0])
    image_paths = [(prefix1+img+" "+class_name+"\n") for img in images]
    #print(image_paths[0])
    if count < 0.8*nrof_classes:
      if len(image_paths)>4:
        test_path=[]
        for x in range(2):
          test_path.append(image_paths[0])
          del image_paths[0]
        filets.writelines(test_path)
    files.writelines(image_paths)
    #if count==2:
    #  break
    #imgae_pathses = []
    #防止圖像大小為0
    #for x in image_paths:
    #  if os.path.getsize(x)>0:
    #    imgae_pathses.append(x)
    #if len(imgae_pathses)==0:
    #  os.rmdir(facedir)
files.close()
filets.close()

python下os模塊的一下有用的用法:

0 重命名:文件和文件夾都是一個(gè)命令:

os.rename(original_dir,new_dir)

1 文件操作:

os.mknod("test.txt")        創(chuàng)建空文件
fp = open("test.txt",w)     直接打開一個(gè)文件,如果文件不存在則創(chuàng)建文件

關(guān)于open 模式:

w     以寫方式打開,
a     以追加模式打開 (從 EOF 開始, 必要時(shí)創(chuàng)建新文件)
r+     以讀寫模式打開
w+     以讀寫模式打開 (參見 w )
a+     以讀寫模式打開 (參見 a )
rb     以二進(jìn)制讀模式打開
wb     以二進(jìn)制寫模式打開 (參見 w )
ab     以二進(jìn)制追加模式打開 (參見 a )
rb+    以二進(jìn)制讀寫模式打開 (參見 r+ )
wb+    以二進(jìn)制讀寫模式打開 (參見 w+ )
ab+    以二進(jìn)制讀寫模式打開 (參見 a+ )

fp.read([size])                     #size為讀取的長度,以byte為單位

fp.readline([size])                 #讀一行,如果定義了size,有可能返回的只是一行的一部分

fp.readlines([size])                #把文件每一行作為一個(gè)list的一個(gè)成員,并返回這個(gè)list。其實(shí)它的內(nèi)部是通過循環(huán)調(diào)用readline()來實(shí)現(xiàn)的。如果提供size參數(shù),size是表示讀取內(nèi)容的總長,也就是說可能只讀到文件的一部分。

fp.write(str)                      #把str寫到文件中,write()并不會(huì)在str后加上一個(gè)換行符

fp.writelines(seq)            #把seq的內(nèi)容全部寫到文件中(多行一次性寫入)。這個(gè)函數(shù)也只是忠實(shí)地寫入,不會(huì)在每行后面加上任何東西。

fp.close()                        #關(guān)閉文件。python會(huì)在一個(gè)文件不用后自動(dòng)關(guān)閉文件,不過這一功能沒有保證,最好還是養(yǎng)成自己關(guān)閉的習(xí)慣。  如果一個(gè)文件在關(guān)閉后還對其進(jìn)行操作會(huì)產(chǎn)生ValueError

fp.flush()                                      #把緩沖區(qū)的內(nèi)容寫入硬盤

fp.fileno()                                      #返回一個(gè)長整型的”文件標(biāo)簽“

fp.isatty()                                      #文件是否是一個(gè)終端設(shè)備文件(unix系統(tǒng)中的)

fp.tell()                                         #返回文件操作標(biāo)記的當(dāng)前位置,以文件的開頭為原點(diǎn)

fp.next()                                       #返回下一行,并將文件操作標(biāo)記位移到下一行。把一個(gè)file用于for … in file這樣的語句時(shí),就是調(diào)用next()函數(shù)來實(shí)現(xiàn)遍歷的。

fp.seek(offset[,whence])              #將文件打操作標(biāo)記移到offset的位置。這個(gè)offset一般是相對于文件的開頭來計(jì)算的,一般為正數(shù)。但如果提供了whence參數(shù)就不一定了,whence可以為0表示從頭開始計(jì)算,1表示以當(dāng)前位置為原點(diǎn)計(jì)算。2表示以文件末尾為原點(diǎn)進(jìn)行計(jì)算。需要注意,如果文件以a或a+的模式打開,每次進(jìn)行寫操作時(shí),文件操作標(biāo)記會(huì)自動(dòng)返回到文件末尾。

fp.truncate([size])                       #把文件裁成規(guī)定的大小,默認(rèn)的是裁到當(dāng)前文件操作標(biāo)記的位置。如果size比文件的大小還要大,依據(jù)系統(tǒng)的不同可能是不改變文件,也可能是用0把文件補(bǔ)到相應(yīng)的大小,也可能是以一些隨機(jī)的內(nèi)容加上去。

也可以直接打開式的新建文件:

  with open('path0.txt','ab') as f:
    for d in arr:
      np.savetxt(f,d,fmt='%5f')    

path0.txt將直接在python腳本所在目錄新建

arr是shape是height x width x channel的numpy數(shù)組,注意,這里這么寫是因?yàn)閚umpy一次只能夠保存一個(gè)height x width維度的數(shù)據(jù)

2 新建、刪除文件夾

新建:os.makedirs()

比如windows下新建E:\\dir\\subdir\\

os.makedirs('E:\\dir\\subdir\\') 或者 os.makedirs('E:/dir/subdir/')

ubuntu下新建就是os.makedirs('/home/dir/subdir/')

復(fù)制文件:

shutil.copyfile("oldfile","newfile")   oldfile和newfile都只能是文件
shutil.copy("oldfile","newfile")oldfile只能是文件夾,newfile可以是文件,也可以是目標(biāo)目錄

復(fù)制文件夾:

shutil.copytree("olddir","newdir")olddir和newdir都只能是目錄,且newdir必須不存在

重命名文件(目錄)

os.rename("oldname","newname")   文件或目錄都是使用這條命令

移動(dòng)文件(目錄)

shutil.move("oldpos","newpos")  

刪除文件

os.remove("file")

刪除目錄

os.rmdir("dir")只能刪除空目錄
shutil.rmtree("dir")空目錄、有內(nèi)容的目錄都可以刪

轉(zhuǎn)換目錄

os.chdir("path")   換路徑

獲取文件大小:os.path.getsize(filename)

3   需要注意的是,在ubuntu下有可能路徑包括~,因此需要展開,展開使用:

path_exp = os.path.expanduser(nam)

4  還有一種情況,路徑相連,需要將一級(jí)一級(jí)的目錄連接起來,os會(huì)自動(dòng)處理層級(jí)目錄之間的/,比如,將目錄/home 和 數(shù)據(jù) 1之間連接起來:

os.path.join('/home', str(1)),

后面也可以為文件名,是一樣的用法

5  路徑存在:用于判斷目錄是否存在

a = os.path.exists(dir)

存在返回True,否則False

6   獲取目錄列表,就是給出的目錄下的文件或目錄列表:

classes = os.listdir(path_exp)

獲得的是path_exp下的所有文件的列表,包含目錄和文件,

os.path.dirname(path) #返回文件路徑,或者是給定路徑去掉最后一個(gè)目錄后的路徑,

還有一種使用方式是用在文件中:

os.path.dirname(__file__)用于獲取所在文件的路徑

7  運(yùn)行shell命令: os.system():

ubuntu下:os.system(‘pwd')

Python腳本工作的目錄路徑: os.getcwd()

讀取和設(shè)置環(huán)境變量:os.getenv() 與os.putenv()

給出當(dāng)前平臺(tái)使用的行終止符:os.linesep Windows使用'\r\n',Linux使用'\n'而Mac使用'\r'

指示你正在使用的平臺(tái):os.name 對于Windows,它是'nt',而對于Linux/Unix用戶,它是'posix'

創(chuàng)建多級(jí)目錄:os.makedirs(r“c:\python\test”)

創(chuàng)建單個(gè)目錄:os.mkdir(“test”)

獲取文件屬性:os.stat(file)

修改文件權(quán)限與時(shí)間戳:os.chmod(file)

終止當(dāng)前進(jìn)程:os.exit()

更全面的os.path用法:

os.path.abspath(path) #返回絕對路徑
os.path.basename(path) #返回文件名

os.path.basename(‘E:a\b\c.jpg')

'c.jpg'

os.path.commonprefix(list) #返回list(多個(gè)路徑)中,所有path共有的最長的路徑。
os.path.dirname(path) #返回文件路徑
os.path.exists(path)  #路徑存在則返回True,路徑損壞返回False
os.path.lexists  #路徑存在則返回True,路徑損壞也返回True
os.path.expanduser(path)  #把path中包含的"~"和"~user"轉(zhuǎn)換成用戶目錄
os.path.expandvars(path)  #根據(jù)環(huán)境變量的值替換path中包含的”$name”和”${name}”
os.path.getatime(path)  #返回最后一次進(jìn)入此path的時(shí)間。
os.path.getmtime(path)  #返回在此path下最后一次修改的時(shí)間。
os.path.getctime(path)  #返回path的大小
os.path.getsize(path)  #返回文件大小,如果文件不存在就返回錯(cuò)誤
os.path.isabs(path)  #判斷是否為絕對路徑
os.path.isfile(path)  #判斷路徑是否為文件
os.path.isdir(path)  #判斷路徑是否為目錄
os.path.islink(path)  #判斷路徑是否為鏈接
os.path.ismount(path)  #判斷路徑是否為掛載點(diǎn)()
os.path.join(path1[, path2[, ...]])  #把目錄和文件名合成一個(gè)路徑
os.path.normcase(path)  #轉(zhuǎn)換path的大小寫和斜杠
os.path.normpath(path)  #規(guī)范path字符串形式
os.path.realpath(path)  #返回path的真實(shí)路徑
os.path.relpath(path[, start])  #從start開始計(jì)算相對路徑
os.path.samefile(path1, path2)  #判斷目錄或文件是否相同
os.path.sameopenfile(fp1, fp2)  #判斷fp1和fp2是否指向同一文件
os.path.samestat(stat1, stat2)  #判斷stat tuple stat1和stat2是否指向同一個(gè)文件

os.path.split(path)  #把路徑分割成dirname和basename,返回一個(gè)元組:
os.path.split(‘E:a\b\c.jpg')

'E:\\a\\b','c.jpg'
os.path.splitdrive(path)   #一般用在windows下,返回驅(qū)動(dòng)器名和路徑組成的元組
os.path.splitext(path)  #分割路徑,返回路徑名和文件擴(kuò)展名的元組

os.path.split(‘E:a\b\c.jpg')

'E:\\a\\b\\c','.jpg'

os.path.splitunc(path)  #把路徑分割為加載點(diǎn)與文件
os.path.walk(path, visit, arg)  #遍歷path,進(jìn)入每個(gè)目錄都調(diào)用visit函數(shù),visit函數(shù)必須有

3個(gè)參數(shù)(arg, dirname, names),dirname表示當(dāng)前目錄的目錄名,names代表當(dāng)前目錄下的所有
文件名,args則為walk的第三個(gè)參數(shù)

os.path.supports_unicode_filenames  #設(shè)置是否支持unicode路徑名

以上這篇python腳本生成caffe train_list.txt的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 一文帶你掌握Python中enumerate函數(shù)和for循環(huán)的對比

    一文帶你掌握Python中enumerate函數(shù)和for循環(huán)的對比

    在Python編程中,循環(huán)是一項(xiàng)常見的任務(wù),而for循環(huán)是最常見的一種,然而,Python提供了enumerate函數(shù),它允許在迭代過程中訪問元素的同時(shí)獲得它們的索引,下面我們就來學(xué)習(xí)一下二者的區(qū)別吧
    2023-11-11
  • pytorch中tensor.expand()和tensor.expand_as()函數(shù)詳解

    pytorch中tensor.expand()和tensor.expand_as()函數(shù)詳解

    今天小編就為大家分享一篇pytorch中tensor.expand()和tensor.expand_as()函數(shù)詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • 10個(gè)示例帶你掌握python中的元組

    10個(gè)示例帶你掌握python中的元組

    這篇文章主要介紹了python中的元組的相關(guān)資料,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2020-11-11
  • python逆向微信指數(shù)爬取實(shí)現(xiàn)步驟

    python逆向微信指數(shù)爬取實(shí)現(xiàn)步驟

    這篇文章主要為大家介紹了python逆向微信指數(shù)爬取的實(shí)現(xiàn)步驟,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-02-02
  • Django 實(shí)現(xiàn)購物車功能的示例代碼

    Django 實(shí)現(xiàn)購物車功能的示例代碼

    這篇文章主要介紹了Django 實(shí)現(xiàn)購物車功能的示例代碼,實(shí)現(xiàn)了刪除產(chǎn)品和顯示購物車的一系列購物車的實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-10-10
  • Java多線程編程中ThreadLocal類的用法及深入

    Java多線程編程中ThreadLocal類的用法及深入

    這篇文章主要介紹了Java多線程編程中ThreadLocal類的用法及深入,嘗試了自己實(shí)現(xiàn)一個(gè)ThreadLocal類以及對相關(guān)的線程安全問題進(jìn)行討論,需要的朋友可以參考下
    2016-06-06
  • Python抓取京東圖書評(píng)論數(shù)據(jù)

    Python抓取京東圖書評(píng)論數(shù)據(jù)

    最近接了個(gè)項(xiàng)目,需要抓取京東圖書的評(píng)論,把代碼放出來給大家分享下,希望能有所幫助
    2014-08-08
  • python實(shí)現(xiàn)兩張圖片的像素融合

    python實(shí)現(xiàn)兩張圖片的像素融合

    這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)兩張圖片的像素融合,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-02-02
  • python set內(nèi)置函數(shù)的具體使用

    python set內(nèi)置函數(shù)的具體使用

    這篇文章主要介紹了python set內(nèi)置函數(shù)的具體使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • python爬蟲的一個(gè)常見簡單js反爬詳解

    python爬蟲的一個(gè)常見簡單js反爬詳解

    這篇文章主要介紹了python爬蟲的一個(gè)常見簡單js反爬詳解我們在寫爬蟲是遇到最多的應(yīng)該就是js反爬了,今天分享一個(gè)比較常見的js反爬,我把js反爬分為參數(shù)由js加密生成和js生成cookie等來操作瀏覽器這兩部分,需要的朋友可以參考下
    2019-07-07

最新評(píng)論