Separate path string into drive and folders

Hi,
using fileparts brings the path, the name and the exentension of a fullfile (e.g., C:\user\files\myFile.txt). Is there a function that separates the path into drive and folders, so that drive = 'C:' folder1 = 'user' folder2 = 'files' ?
Thx, Philipp

 채택된 답변

Azzi Abdelmalek
Azzi Abdelmalek 2013년 7월 24일

8 개 추천

s='C:\user\files\myFile.txt'
out=regexp(s,'\','split')

댓글 수: 6

For a general solution (would work on any OS) I would suggest
endout=regexp(s,filesep,'split')
Best
baby
baby 2022년 2월 25일
works for me as well.
Riad
Riad 2024년 5월 17일
Hello,
filesep is equivalent to "\" and it works fine for a kind of paths. But I've troubles when I want to separate paths that use this separator "/". I mean: when you derive blocks paths (using "find_system") you'll get paths like this : 'Swc_MTR/Run_MTR_1ms_sys/COMP_/In1' and :
regexp('Swc_MTR/Run_MTR_1ms_sys/COMP_/In1',filesep,'split')
won't work !
I want to avoid strsplit function by using a function that can work for both Windows/Linux OS !
Anyone can help ?
@Mohamed Riad: because you are already using REGEXP this is quite easy:
regexp('Swc_MTR/Run_MTR_1ms_sys/COMP_/In1','[/\\]+','split')
ans = 1x4 cell array
{'Swc_MTR'} {'Run_MTR_1ms_sys'} {'COMP_'} {'In1'}
Riad
Riad 2024년 5월 21일
Hi @Stephen23 there more easier way by using strsplit but I want to avoid using either "/" or "\" in the script (on the server, I've a Linux OS):
strsplit('Swc_MTR/Run_MTR_1ms_sys/COMP_/In1','/')
ans =
1×4 cell array
{'Swc_MTR'} {'Run_MTR_1ms_sys'} {'COMP_'} {'In1'}
"filesep is equivalent to "\" and it works fine for a kind of paths"
No, what FILESEP is depends on the OS that MATLAB is currently running on.
"I want to avoid strsplit function by using a function that can work for both Windows/Linux OS !"
And now you write that you want to use STRSPLIT: your requirements keep on changing.
"I want to avoid using either "/" or "\" in the script (on the server, I've a Linux OS)"
I thought the requirement is to split on either of the path separators, which is also easy with STRSPLIT:
strsplit('Swc_MTR/Run_MTR_1ms_sys/COMP_/In1',{'/','\'})
ans = 1x4 cell array
{'Swc_MTR'} {'Run_MTR_1ms_sys'} {'COMP_'} {'In1'}

댓글을 달려면 로그인하십시오.

추가 답변 (2개)

Christian Schwermer
Christian Schwermer 2018년 9월 9일

6 개 추천

The shortest solution is to split the string using filesep as delimeter. filesep returns the platform-specific file separator "\" or "/".
pathparts = strsplit(s,filesep);
Dominique
Dominique 2023년 7월 19일

0 개 추천

path = uigetdir()
foldername = strsplit(path,"\");
foldername = foldername(end);

카테고리

도움말 센터File Exchange에서 Filename Construction에 대해 자세히 알아보기

질문:

2013년 7월 24일

댓글:

2024년 5월 21일

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by