디렉토리에서 glob을 사용하여 특정 확장자를 가진 파일을 가져올 수 있지만 전체 경로가 아닌 파일 이름 자체 만 가져올 수있는 방법이 있습니까?
디렉토리에서 glob을 사용하여 특정 확장자를 가진 파일을 가져올 수 있지만 전체 경로가 아닌 파일 이름 자체 만 가져올 수있는 방법이 있습니까?
답변:
이것은 누군가를 도울 수 있습니다.
names = [os.path.basename(x) for x in glob.glob('/your_path')]
os.path.basename이 나를 위해 작동합니다.
다음은 코드 예입니다.
import sys,glob
import os
expectedDir = sys.argv[1] ## User input for directory where files to search
for fileName_relative in glob.glob(expectedDir+"**/*.txt",recursive=True): ## first get full file name with directores using for loop
print("Full file name with directories: ", fileName_relative)
fileName_absolute = os.path.basename(fileName_relative) ## Now get the file name with os.path.basename
print("Only file name: ", fileName_absolute)
출력 :
Full file name with directories: C:\Users\erinksh\PycharmProjects\EMM_Test2\venv\Lib\site-packages\wheel-0.33.6.dist-info\top_level.txt
Only file name: top_level.txt
나는 상대 globbing (특히 zip 파일에 항목을 추가해야 할 때)에 대한 솔루션을 계속 다시 작성합니다 . 이것은 일반적으로 다음과 같이 보입니다.
# Function
def rel_glob(pattern, rel):
"""glob.glob but with relative path
"""
for v in glob.glob(os.path.join(rel, pattern)):
yield v[len(rel):].lstrip("/")
# Use
# For example, when you have files like: 'dir1/dir2/*.py'
for p in rel_glob("dir2/*.py", "dir1"):
# do work
pass
CSV 파일을 찾는 경우 :
file = [os.path.basename(x) for x in glob.glob(r'C:\Users\rajat.prakash\Downloads//' + '*.csv')]
EXCEL 파일을 찾는 경우 :
file = [os.path.basename(x) for x in glob.glob(r'C:\Users\rajat.prakash\Downloads//' + '*.xlsx')]