Python を使用してディレクトリ内のファイル数をカウントする必要があります。
最も簡単な方法は だと思いますがlen(glob.glob('*'))
、それはディレクトリ自体もファイルとしてカウントします。
ディレクトリ内のファイルだけをカウントする方法はありますか?
os.listdir()
を使用するよりもわずかに効率的ですglob.glob
。ファイル名が通常のファイル (ディレクトリやその他のエンティティではない) かどうかをテストするには、次を使用しますos.path.isfile()
。
import os, os.path
# simple version for working with CWD
print len([name for name in os.listdir('.') if os.path.isfile(name)])
# path joining version for other paths
DIR = '/tmp'
print len([name for name in os.listdir(DIR) if os.path.isfile(os.path.join(DIR, name))])
import os
path, dirs, files = next(os.walk("/usr/lib"))
file_count = len(files)
すべての種類のファイルについて、サブディレクトリには以下が含まれます。
import os
list = os.listdir(dir) # dir is your directory path
number_files = len(list)
print number_files
ファイルのみ(サブディレクトリを避ける):
import os
onlyfiles = next(os.walk(dir))[2] #dir is your directory path as string
print len(onlyfiles)
ここで fnmatch が非常に便利です。
import fnmatch
print len(fnmatch.filter(os.listdir(dirpath), '*.txt'))
def directory(path,extension):
list_dir = []
list_dir = os.listdir(path)
count = 0
for file in list_dir:
if file.endswith(extension): # eg: '.txt'
count += 1
return count
これはos.listdir
、任意のディレクトリを使用して機能します。
import os
directory = 'mydirpath'
number_of_files = len([item for item in os.listdir(directory) if os.path.isfile(os.path.join(directory, item))])
これはジェネレーターで単純化でき、次の方法で少し高速化できます。
import os
isfile = os.path.isfile
join = os.path.join
directory = 'mydirpath'
number_of_files = sum(1 for item in os.listdir(directory) if isfile(join(directory, item)))
def count_em(valid_path):
x = 0
for root, dirs, files in os.walk(valid_path):
for f in files:
x = x+1
print "There are", x, "files in this directory."
return x
この投稿から取得
import os
def count_files(in_directory):
joiner= (in_directory + os.path.sep).__add__
return sum(
os.path.isfile(filename)
for filename
in map(joiner, os.listdir(in_directory))
)
>>> count_files("/usr/lib")
1797
>>> len(os.listdir("/usr/lib"))
2049
以下は、私が便利だと思った簡単な 1 行のコマンドです。
print int(os.popen("ls | wc -l").read())
Luke のコードの再フォーマット。
import os
print len(os.walk('/usr/lib').next()[2])
オペレーティング システムの標準シェルを使用する場合は、純粋な pythonic の方法を使用するよりもはるかに高速に結果を取得できます。
Windows の例:
import os
import subprocess
def get_num_files(path):
cmd = 'DIR \"%s\" /A-D /B /S | FIND /C /V ""' % path
return int(subprocess.check_output(cmd, shell=True))
受け入れられた回答として正しいかもしれない別の回答を見つけました。
for root, dirs, files in os.walk(input_path):
for name in files:
if os.path.splitext(name)[1] == '.TXT' or os.path.splitext(name)[1] == '.txt':
datafiles.append(os.path.join(root,name))
print len(files)
私はこれを行い、これはフォルダー内のファイルの数(Attack_Data)を返しました...これは正常に機能します。
import os
def fcount(path):
#Counts the number of files in a directory
count = 0
for f in os.listdir(path):
if os.path.isfile(os.path.join(path, f)):
count += 1
return count
path = r"C:\Users\EE EKORO\Desktop\Attack_Data" #Read files in folder
print (fcount(path))
os.scandir()
の代わりにを使用する、私が書いた単純なユーティリティ関数ですos.listdir()
。
import os
def count_files_in_dir(path: str) -> int:
file_entries = [entry for entry in os.scandir(path) if entry.is_file()]
return len(file_entries)
主な利点は、他の回答に示されているように、の必要性os.path.is_file()
が排除され、os.DirEntry
インスタンスのis_file()
必要性も排除されることです。os.path.join(DIR, file_name)