如何从Python路径中获取不带扩展名的文件名?
如何从Python路径中获取不带扩展名的文件名?
Answers:
获取不带扩展名的文件名:
import os
print(os.path.splitext("/path/to/some/file.txt")[0])
印刷品:
/path/to/some/file
重要说明:如果文件名有多个点,则仅删除最后一个扩展名之后的扩展名。例如:
import os
print(os.path.splitext("/path/to/some/file.txt.zip.asc")[0])
印刷品:
/path/to/some/file.txt.zip
如果您需要处理这种情况,请参见下面的其他答案。
splitext('kitty.jpg.zip')
给出('kitty.jpg', '.zip')
)。
splitext(basename('/some/path/to/file.txt'))[0]
(我总是似乎在做)
您可以使用以下方法制作自己的:
>>> import os
>>> base=os.path.basename('/root/dir/sub/file.ext')
>>> base
'file.ext'
>>> os.path.splitext(base)
('file', '.ext')
>>> os.path.splitext(base)[0]
'file'
重要说明:如果.
文件名中有多个,则仅删除最后一个。例如:
/root/dir/sub/file.ext.zip -> file.ext
/root/dir/sub/file.ext.tar.gz -> file.ext.tar
请参阅下面的其他答案。
os
。
os.path
解决方案一样,这只会剥离一个扩展名(或suffix
称为扩展名pathlib
)。Path('a.b.c').stem == 'a.b'
Path(Path('a.b.c').stem).stem
.with_suffix('')
是必经之路。您可能要循环播放直到p.suffix == ''
。
在Python 3.4+中,您可以使用pathlib
解决方案
from pathlib import Path
print(Path(your_path).resolve().stem)
resolve()
走这条路?是否真的有可能获得文件的路径,而没有文件名而不是文件路径呢?这意味着,如果您提供符号链接的路径,则将返回符号链接指向的文件的文件名(不带扩展名)。
resolve()
是帮助解决多点问题。如果路径为“ ./foo.tar.gz”,则以下有关使用索引的答案将不起作用
https://docs.python.org/3/library/os.path.html
在python 3 pathlib中,“ pathlib模块提供了高级路径对象。” 所以,
>>> from pathlib import Path
>>> p = Path("/a/b/c.txt")
>>> print(p.with_suffix(''))
\a\b\c
>>> print(p.stem)
c
如果您想保留文件的路径,然后删除扩展名
>>> file = '/root/dir/sub.exten/file.data.1.2.dat'
>>> print ('.').join(file.split('.')[:-1])
/root/dir/sub.exten/file.data.1.2
'/root/dir/sub.exten/file.data.1.2.dat'.rsplit('.', 1)
如果扩展名中包含多个点,则os.path.splitext()将不起作用。
例如images.tar.gz
>>> import os
>>> file_path = '/home/dc/images.tar.gz'
>>> file_name = os.path.basename(file_path)
>>> print os.path.splitext(file_name)[0]
images.tar
您可以只在基本名称中找到第一个点的索引,然后对基本名称进行切片以仅获取不带扩展名的文件名。
>>> import os
>>> file_path = '/home/dc/images.tar.gz'
>>> file_name = os.path.basename(file_path)
>>> index_of_dot = file_name.index('.')
>>> file_name_without_extension = file_name[:index_of_dot]
>>> print file_name_without_extension
images
'haystack'.index('needle')
如果.
在干草堆中找不到针(在上述情况下为圆点,),则会引发ValueError异常。也没有任何扩展名的文件。
但是即使导入os,也无法将其称为path.basename。是否可以直接将其作为基名来调用?
import os
,然后使用 os.path.basename
import
ing os
并不意味着您os.foo
无需参考即可使用os
。
from os import foo
。
os
如果该模块具有名为的成员,则您具有该模块的非标准版本foo
。
path
或walk
)。
我以为我会使用os.path.splitext的变体不需要使用数组索引的情况的使用进行修改。
该函数始终返回一(root, ext)
对,因此可以安全使用:
root, ext = os.path.splitext(path)
例:
>>> import os
>>> path = 'my_text_file.txt'
>>> root, ext = os.path.splitext(path)
>>> root
'my_text_file'
>>> ext
'.txt'
其他方法不会删除多个扩展名。有些文件名也没有扩展名。此代码段同时处理这两个实例,并且在Python 2和3中均可使用。它从路径中获取基本名称,将值分割为点,然后返回第一个(即文件名的初始部分)。
import os
def get_filename_without_extension(file_path):
file_basename = os.path.basename(file_path)
filename_without_extension = file_basename.split('.')[0]
return filename_without_extension
这是一组要运行的示例:
example_paths = [
"FileName",
"./FileName",
"../../FileName",
"FileName.txt",
"./FileName.txt.zip.asc",
"/path/to/some/FileName",
"/path/to/some/FileName.txt",
"/path/to/some/FileName.txt.zip.asc"
]
for example_path in example_paths:
print(get_filename_without_extension(example_path))
在每种情况下,打印出的值是:
FileName
Path('/path/to/file.txt').stem
。(1,23μs与8.39μs)
多扩展识别过程。适用于str
和unicode
路径。适用于Python 2和3。
import os
def file_base_name(file_name):
if '.' in file_name:
separator_index = file_name.index('.')
base_name = file_name[:separator_index]
return base_name
else:
return file_name
def path_base_name(path):
file_name = os.path.basename(path)
return file_base_name(file_name)
行为:
>>> path_base_name('file')
'file'
>>> path_base_name(u'file')
u'file'
>>> path_base_name('file.txt')
'file'
>>> path_base_name(u'file.txt')
u'file'
>>> path_base_name('file.tar.gz')
'file'
>>> path_base_name('file.a.b.c.d.e.f.g')
'file'
>>> path_base_name('relative/path/file.ext')
'file'
>>> path_base_name('/absolute/path/file.ext')
'file'
>>> path_base_name('Relative\\Windows\\Path\\file.txt')
'file'
>>> path_base_name('C:\\Absolute\\Windows\\Path\\file.txt')
'file'
>>> path_base_name('/path with spaces/file.ext')
'file'
>>> path_base_name('C:\\Windows Path With Spaces\\file.txt')
'file'
>>> path_base_name('some/path/file name with spaces.tar.gz.zip.rar.7z')
'file name with spaces'
为了方便起见,一个简单的函数包装了以下两种方法os.path
:
def filename(path):
"""Return file name without extension from path.
See https://docs.python.org/3/library/os.path.html
"""
import os.path
b = os.path.split(path)[1] # path, *filename*
f = os.path.splitext(b)[0] # *file*, ext
#print(path, b, f)
return f
经过Python 3.5测试。
解决此问题的最简单方法是
import ntpath
print('Base name is ',ntpath.basename('/path/to/the/file/'))
这样可以节省您的时间和计算成本。
非常非常非常简单没有其他模块!
import os
p = r"C:\Users\bilal\Documents\face Recognition python\imgs\northon.jpg"
# Get the filename only from the initial file path.
filename = os.path.basename(p)
# Use splitext() to get filename and extension separately.
(file, ext) = os.path.splitext(filename)
# Print outcome.
print("Filename without extension =", file)
print("Extension =", ext)
我们可以做一些简单的split
/ pop
因为在这里看到(魔术https://stackoverflow.com/a/424006/1250044),提取文件名(尊重Windows和POSIX差异)。
def getFileNameWithoutExtension(path):
return path.split('\\').pop().split('/').pop().rsplit('.', 1)[0]
getFileNameWithoutExtension('/path/to/file-0.0.1.ext')
# => file-0.0.1
getFileNameWithoutExtension('\\path\\to\\file-0.0.1.ext')
# => file-0.0.1
import os
list = []
def getFileName( path ):
for file in os.listdir(path):
#print file
try:
base=os.path.basename(file)
splitbase=os.path.splitext(base)
ext = os.path.splitext(base)[1]
if(ext):
list.append(base)
else:
newpath = path+"/"+file
#print path
getFileName(newpath)
except:
pass
return list
getFileName("/home/weexcel-java3/Desktop/backup")
print list