国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

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

2020-01-04 15:19:53
字體:
來源:轉載
供稿:網友

首先給出代碼:

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一個數據集下有多少個文件夾,就是說有多少個人,多少個類別nrof_classes = len(classes)count=0files = open("train_list.txt",'w')filets = open("test_list.txt",'w')count_u=0for 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 重命名:文件和文件夾都是一個命令:

os.rename(original_dir,new_dir)

1 文件操作:

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

關于open 模式:

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

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

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

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

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

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

fp.close()                        #關閉文件。python會在一個文件不用后自動關閉文件,不過這一功能沒有保證,最好還是養成自己關閉的習慣。  如果一個文件在關閉后還對其進行操作會產生ValueError

fp.flush()                                      #把緩沖區的內容寫入硬盤

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

fp.isatty()                                      #文件是否是一個終端設備文件(unix系統中的)

fp.tell()                                         #返回文件操作標記的當前位置,以文件的開頭為原點

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

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

fp.truncate([size])                       #把文件裁成規定的大小,默認的是裁到當前文件操作標記的位置。如果size比文件的大小還要大,依據系統的不同可能是不改變文件,也可能是用0把文件補到相應的大小,也可能是以一些隨機的內容加上去。

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

  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數組,注意,這里這么寫是因為numpy一次只能夠保存一個height x width維度的數據

2 新建、刪除文件夾

新建:os.makedirs()

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

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

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

復制文件:

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

復制文件夾:

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

重命名文件(目錄)

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

移動文件(目錄)

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

刪除文件

os.remove("file")

刪除目錄

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

轉換目錄

os.chdir("path")   換路徑

獲取文件大?。簅s.path.getsize(filename)

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

path_exp = os.path.expanduser(nam)

4  還有一種情況,路徑相連,需要將一級一級的目錄連接起來,os會自動處理層級目錄之間的/,比如,將目錄/home 和 數據 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) #返回文件路徑,或者是給定路徑去掉最后一個目錄后的路徑,

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

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

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

ubuntu下:os.system(‘pwd')

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

讀取和設置環境變量:os.getenv() 與os.putenv()

給出當前平臺使用的行終止符:os.linesep Windows使用'/r/n',Linux使用'/n'而Mac使用'/r'

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

創建多級目錄:os.makedirs(r“c:/python/test”)

創建單個目錄:os.mkdir(“test”)

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

修改文件權限與時間戳:os.chmod(file)

終止當前進程: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(多個路徑)中,所有path共有的最長的路徑。
os.path.dirname(path) #返回文件路徑
os.path.exists(path)  #路徑存在則返回True,路徑損壞返回False
os.path.lexists  #路徑存在則返回True,路徑損壞也返回True
os.path.expanduser(path)  #把path中包含的"~"和"~user"轉換成用戶目錄
os.path.expandvars(path)  #根據環境變量的值替換path中包含的”$name”和”${name}”
os.path.getatime(path)  #返回最后一次進入此path的時間。
os.path.getmtime(path)  #返回在此path下最后一次修改的時間。
os.path.getctime(path)  #返回path的大小
os.path.getsize(path)  #返回文件大小,如果文件不存在就返回錯誤
os.path.isabs(path)  #判斷是否為絕對路徑
os.path.isfile(path)  #判斷路徑是否為文件
os.path.isdir(path)  #判斷路徑是否為目錄

os.path.islink(path)  #判斷路徑是否為鏈接
os.path.ismount(path)  #判斷路徑是否為掛載點()
os.path.join(path1[, path2[, ...]])  #把目錄和文件名合成一個路徑
os.path.normcase(path)  #轉換path的大小寫和斜杠
os.path.normpath(path)  #規范path字符串形式
os.path.realpath(path)  #返回path的真實路徑
os.path.relpath(path[, start])  #從start開始計算相對路徑
os.path.samefile(path1, path2)  #判斷目錄或文件是否相同
os.path.sameopenfile(fp1, fp2)  #判斷fp1和fp2是否指向同一文件
os.path.samestat(stat1, stat2)  #判斷stat tuple stat1和stat2是否指向同一個文件

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

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

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

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

os.path.splitunc(path)  #把路徑分割為加載點與文件
os.path.walk(path, visit, arg)  #遍歷path,進入每個目錄都調用visit函數,visit函數必須有

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

os.path.supports_unicode_filenames  #設置是否支持unicode路徑名

以上這篇python腳本生成caffe train_list.txt的方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 深圳市| 泗水县| 鹤峰县| 元谋县| 武胜县| 蒙自县| 美姑县| 滦南县| 万安县| 平邑县| 光山县| 邵阳市| 潜江市| 武穴市| 阜宁县| 北宁市| 夏河县| 白沙| 昂仁县| 牙克石市| 东城区| 海口市| 兴和县| 通城县| 武隆县| 哈密市| 灵丘县| 固安县| 伊春市| 广丰县| 郸城县| 曲阳县| 玉田县| 阿克陶县| 河东区| 闽侯县| 聂荣县| 怀柔区| 武清区| 临汾市| 库车县|