I like to import a string with multiple pathnames
1 回表示 (過去 30 日間)
古いコメントを表示
Hello,
I have a string with multiple substrings. Each of the substrings is a pathname. How can I use importdata or textscan to import these substrings in seperate tables?
2 件のコメント
KSSV
2018 年 3 月 26 日
You have those strings in a text file? Why don't you show the sample of text file?
回答 (2 件)
KSSV
2018 年 3 月 26 日
Try this:
[FileName,PathName] = uigetfile('../*.txt','MultiSelect','on','choose','the path');
numfiles = length(FileName);
a = cell(numfiles,1) ;
for ii = 1:numfiles
c = char (FileName{ii});
string2=strcat(PathName,c);
a{ii} = importdata(string2);
end
2 件のコメント
Stephen23
2018 年 3 月 26 日
Do not use strcat for filenames/paths! Always use fullfile.
Also that char does nothing.
Stephen23
2018 年 3 月 26 日
編集済み: Stephen23
2018 年 3 月 26 日
uigetfile does not return strings, it returns a cell array of char vectors. Iterating over a cell array is easy, so just do that. Also use fullfile rather than concatenating strings using strcat (or anything else).
[fnm,pnm] = uigetfile('../*.txt','MultiSelect','on','choose','the path');
C = cell(1,numel(fnm));
for k = 1:numel(fnm)
C{K} = importdata(fullfile(pnm,fnm{k}));
end
2 件のコメント
Stephen23
2018 年 3 月 26 日
編集済み: Stephen23
2018 年 3 月 26 日
"Is it possible that I get this as result?"
Of course it is possible. Read the importdata help to know what it returns: the structure and its fieldnames are clearly explained there. Note that you could easily convert the cell array of scalar structures to a more convenient non-scalar structure:
S = [C{:}];
S(1).data
S(1).colheaders
...
S(2).data
...
参考
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!