Odpowiedzi:
Użyj os.path.normpath
, a następnie os.path.basename
:
>>> os.path.basename(os.path.normpath('/folderA/folderB/folderC/folderD/'))
'folderD'
Pierwszy usuwa wszelkie końcowe ukośniki, drugi daje ostatnią część ścieżki. Użycie basename
daje tylko wszystko po ostatnim ukośniku, co w tym przypadku jest ''
.
Mógłbyś
>>> import os
>>> os.path.basename('/folderA/folderB/folderC/folderD')
AKTUALIZACJA 1: To podejście działa, jeśli podasz /folderA/folderB/folderC/folderD/xx.py. To daje xx.py jako basename. Chyba nie tego chcesz. Więc możesz to zrobić -
>>> import os
>>> path = "/folderA/folderB/folderC/folderD"
>>> if os.path.isdir(path):
dirname = os.path.basename(path)
AKTUALIZACJA 2: Jak zauważył Lars , wprowadzanie zmian w celu dostosowania końcowego / „.
>>> from os.path import normpath, basename
>>> basename(normpath('/folderA/folderB/folderC/folderD/'))
'folderD'
W Pythonie 3 możesz użyć pathlib
modułu ( pathlib.PurePath
na przykład):
>>> import pathlib
>>> path = pathlib.PurePath('/folderA/folderB/folderC/folderD/')
>>> path.name
'folderD'
Jeśli chcesz nazwę ostatniego folderu, w którym znajduje się plik:
>>> path = pathlib.PurePath('/folderA/folderB/folderC/folderD/file.py')
>>> path.parent.name
'folderD'
Oto moje podejście:
>>> import os
>>> print os.path.basename(
os.path.dirname('/folderA/folderB/folderC/folderD/test.py'))
folderD
>>> print os.path.basename(
os.path.dirname('/folderA/folderB/folderC/folderD/'))
folderD
>>> print os.path.basename(
os.path.dirname('/folderA/folderB/folderC/folderD'))
folderC
Szukałem rozwiązania, aby uzyskać ostatnią nazwę folderu, w którym znajduje się plik, użyłem go split
dwa razy, aby uzyskać właściwą część. To nie jest pytanie, ale Google przeniosło mnie tutaj.
pathname = "/folderA/folderB/folderC/folderD/filename.py"
head, tail = os.path.split(os.path.split(pathname)[0])
print(head + " " + tail)
Naiwne rozwiązanie (Python 2.5.2+):
s="/path/to/any/folder/orfile"
desired_dir_or_file = s[s.rindex('/',0,-1)+1:-1] if s.endswith('/') else s[s.rindex('/')+1:]
W tym celu podoba mi się metoda Path części :
grandparent_directory, parent_directory, filename = Path(export_filename).parts[-3:]
log.info(f'{t: <30}: {num_rows: >7} Rows exported to {grandparent_directory}/{parent_directory}/{filename}')
path = "/folderA/folderB/folderC/folderD/"
last = path.split('/').pop()
os.path
modułu.
str = "/folderA/folderB/folderC/folderD/"
print str.split("/")[-2]
folderD
. niefolderC
os.path
modułu.
rstrip('/')
, że będzie to prostsze, ale szybko zdałem sobie sprawę, że będę musiał użyćrstrip(os.path.sep)
, więc oczywiście użycienormpath
jest uzasadnione.