ich habe hier ein Code der mir meine Excel Tabelle einliest.
Wie kann ich das automatisieren, dass Matlab das automatisch mit allen Dateien in diesem Ordner macht?
Code:
function n = importtable(filename, startRow, endRow)
%IMPORTFILE1 Import numeric data from a text file as a matrix.
% N = IMPORTFILE1(FILENAME) Reads data from text file FILENAME for the % default selection.
%
% N = IMPORTFILE1(FILENAME, STARTROW, ENDROW) Reads data from rows % STARTROW through ENDROW of text file FILENAME.
%
% Example: % n = importfile1('123456_H131-88_n917_a30_Config01.csv', 3, 51202);
%
% See also TEXTSCAN.
% Auto-generated by MATLAB on 2015/10/09 22:09:50
%% Initialize variables.
delimiter = ',';
if nargin<=2
startRow = 3;
endRow = inf;
end
%% Open the text file.
fileID = fopen(filename,'r');
%% Read columns of data according to format string. % This call is based on the structure of the file used to generate this % code. If an error occurs for a different file, try regenerating the code % from the Import Tool.
dataArray = textscan(fileID, formatSpec, endRow(1)-startRow(1)+1, 'Delimiter', delimiter, 'EmptyValue' ,NaN,'HeaderLines', startRow(1)-1, 'ReturnOnError', false);
for block=2:length(startRow) frewind(fileID);
dataArrayBlock = textscan(fileID, formatSpec, endRow(block)-startRow(block)+1, 'Delimiter', delimiter, 'EmptyValue' ,NaN,'HeaderLines', startRow(block)-1, 'ReturnOnError', false);
for col=1:length(dataArray)
dataArray{col} = [dataArray{col};dataArrayBlock{col}];
end end
%% Post processing for unimportable data. % No unimportable data rules were applied during the import, so no post % processing code is included. To generate code which works for % unimportable data, select unimportable cells in a file and regenerate the % script.
%% Create output variable
n = table(dataArray{1:end-1}, 'VariableNames', {'B1','B2','B3','B4','B5','B6','B7','B9','B10','B11','B12','B19','B15','B17','B18','B20','Trigger','Drehzahl'});
nein es hat sich nur nach dem gleich problem angehört. in dem anderen thread war ja auch von mehrren ordnern die rede. wenn du das andere problem lösen kontest wäre es nett wenn du das dann in den thread schreibst oder sogar auch die lösung angiebtst für nutzer die später vielleicht auf das selbe problem stoßen
_________________
doch ich dachte blos das hast du selber schon in der anderen aufgabe implementiert. so wie jan gesagt hat mit dir etc alle daten finden und dann einfach eine schleife über die namen laufen lassen das die dann als filename in deine importfile eingesetzt werden. guck dir auch mal
fullfile
das könnte hilfreich sein. wenn es unterordner gibt etc dann kannst du mal im FEX nach einer lösung gucken die auch alle unterordner durchsucht. da gab es schon was.
_________________
also, das mit dem importieren klappt jetzt ganz gut!
allerdings habe ich noch das problem, dass wenn ich alle dateien importiere, er mir immer die vorherige überschreibt, sodass ich am schluss nur die letzte datei importiert habe.
Wie kann ich sagen, das er die Outputs durchnummerieren soll?
So sieht es bis jetzt aus:
Code:
csvfiles = dir('*.csv');
for allFiles = csvfiles'
csv = importtable_test(allFiles.name, 3, inf);
end
dann musst du halt nicht immer das vorherige ergebniss überschreiben sondern jeweisl in einem eigenen eintrag speichern. das könnte man mit cell arrays machen oder mit struckts oder mit matrizen je nachdem.
Ich bekomme es einfach nicht hin, was ist denn daran falsch? (hab auch schon ein paar andere Varianten durchprobiert
Code:
csvfiles = dir('*.csv');
num_files = length(csvfiles);
for allFiles = csvfiles'
end for i = 1:num_files;
csv = allFiles;
csv(i) = importtable_test(allFiles.name, 3, inf);
end
csvfiles = dir('*.csv');
num_files = length(csvfiles);
for allFiles = csvfiles'
end for i = 1:num_files;
csv = evalin('base',csv(i).name);
csv{i} = importtable_test(allFiles.name, 3, inf);
end
Aber wie bekomme ich jetzt meine Variablen aus dem Cell Array in meine Workspace?
Bekomme ich das gleich hin in der Funktion oben, oder muss ich die jetzt extra noch extrahieren?
Also ich habe ja jetzt durch "csv{i}" ein array erstellt indem sich alle meine tabellen csv1, csv2, csv3... befinden (Bild 1&2). Ich hätte aber gerne, dass diese Tabellen als Variable ("matrix") in meiner Workspace auftauchen. So wie es auch ist, wenn ich nur eine csv-Tabelle reinlade (Bild 3).
Also das es aussieht wie in Bild 4 nur automatisch
Du kannst Beiträge in dieses Forum schreiben. Du kannst auf Beiträge in diesem Forum antworten. Du kannst deine Beiträge in diesem Forum nicht bearbeiten. Du kannst deine Beiträge in diesem Forum nicht löschen. Du kannst an Umfragen in diesem Forum nicht mitmachen. Du kannst Dateien in diesem Forum posten Du kannst Dateien in diesem Forum herunterladen
MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.