ホームページ  >  記事  >  バックエンド開発  >  Pythonスクリプトを使用してcaffe train_list.txtを生成する方法

Pythonスクリプトを使用してcaffe train_list.txtを生成する方法

不言
不言オリジナル
2018-04-28 14:57:512293ブラウズ

以下は caffe train_list.txt を生成するための Python スクリプトを共有する方法です。これは良い参考値なので、皆さんのお役に立てれば幸いです。一緒に見てみましょう

まずコードを与えます:

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=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 Rename: ファイルとフォルダーは両方とも1つのコマンドです:

os. original_dir,new_dir)

1 ファイル操作:

os.mknod("test.txt") 空のファイルを作成します
fp = open("test.txt",w) ファイルを直接開きます。ファイルが存在しないため、ファイルを作成します

オープンモードについて:

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])#read read a lineを読みます。 .readlines([size]) メンバーを取得し、このリストを返します。実際、これはループ内で readline() を呼び出すことによって内部的に実装されます。 size パラメータが指定されている場合、size は読み取られるコンテンツの全長を表します。これは、ファイルの一部のみが読み取られることを意味します。 Tfp.write (STR) #str をファイルに書き込みます。WRITE () は行を追加しません。ffp.writelines (SEQ) #後ろの STR 行はすべて一度に書き込まれます)。この関数も、各行の後に何も追加せずに、忠実に記述するだけです。

fp.close() Python は、使用されなくなったファイルを自動的に閉じますが、この機能は保証されていません。自分でファイルを閉じる習慣を身に付けることをお勧めします。ファイルが閉じた後に動作している場合、valueRrorが発生します。

fp.next() ファイル操作フラグを次の行に移動します。ファイルが for...in file などのステートメントで使用される場合、トラバーサルを実装するために next() 関数が呼び出されます。

fp.seek(offset[,whence])              #将文件打操作标记移到offset的位置。这个offset一般是相对于文件的开头来计算的,一般为正数。但如果提供了whence参数就不一定了,whence可以为0表示从头开始计算,1表示以当前位置为原点计算。2表示以文件末尾为原点进行计算。需要注意,如果文件以a或a+的模式打开,每次进行写操作时,文件操作标记会自动返回到文件末尾。

fp.truncate([size])                       #把文件裁成规定的大小,默认的是裁到当前文件操作标记的位置。如果size比文件的大小还要大,依据系统的不同可能是不改变文件,也可能是用0把文件补到相应的大小,也可能是以一些随机的内容加上去。

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

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

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")   换路径

获取文件大小:os.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:abc.jpg')

'c.jpg'

os.path.commonprefix(list) #リスト内のすべてのパスの共通プレフィックスを返します (複数のパス) ) 最長のパス。
os.path.dirname(path) #ファイルパスを返します
os.path.exists(path) #パスが存在する場合はTrueを返し、パスが破損している場合はFalseを返します
os.path.lexists #パスが存在する場合はTrueを返します、パスが破損している場合は戻ります True
os.path.expanduser(path) #パスに含まれる「~」と「~user」をユーザーディレクトリに変換します
os.path.expandvars(path) #「」を置き換えます環境変数name"と${name}"の値に従ってパスに含まれる$"
os.path.getatime(path) #このパスが最後に入力された時刻を返します。
os.path.getmtime(path) #このパスの最後の変更時刻を返します。
os.path.getctime(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[, ...]] ) #ディレクトリ名とファイル名を1つのパスに結合します
os.path .normcase(path) #パスの大文字と小文字とスラッシュを変換します
os.path.normpath(path) #パス文字列を正規化します
os.path.realpath (path) # path の実パスを返す
os.path.relpath (path[, start]) # start からの相対パスを計算
os.path.samefile(path1, path2) # ディレクトリまたはファイルがSame
os.path.sameopenfile(fp1, fp2) #fp1 と fp2 が同じファイルを指しているかどうかを判断します
os.path.samestat(stat1, stat2) #stat タプル stat1 と stat2 が同じファイルを指しているかどうかを判断します

os.path.split(path) #パスをディレクトリ名とベース名に分割し、タプルを返します :
os.path.split('E:abc.jpg')

'E:\a\b ','c.jpg'
os.path.splitdrive(path) #通常 Windows で使用され、ドライブ名とパスのタプルを返します
os.path.splitext(path) #パスを分割し、パス名とパスのタプルを返しますファイル拡張子

os.path.split('E:abc.jpg')

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

os.path.splitunc(path) #パスをロードポイントとファイルに分割します
os.path.walk(path, visit, arg) #各ディレクトリに入るときにパスをトラバースし、visit 関数を呼び出します

3 つのパラメータ (arg, dirname) が必要です。 dirname は現在のディレクトリのディレクトリ名を表し、names は walk

os.path.supports_unicode_filenames の 3 番目のパラメータです #Unicode パス名をサポートするかどうかを設定します


以上がPythonスクリプトを使用してcaffe train_list.txtを生成する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。