Hallo Harald, ich bin dabei zuvor alles zu überprüfen bevor ich schreibe. Aber hier hab ich ein Problem das ich nicht beschreiben kann.
Es geht dabei um die Speicherung meiner Datei. Es funktioniert alles siehe Code.
Das Problem ist wenn ich die Datei in Excel öffne hat diese Datei in Spalte 1 andere Werte wie in Matlab unter meinem Workspace(Fenster).
Die Werte von F=Fenster die ich speichern möchte sind in Spalte 1 nicht die gleichen wie in Matlab? Kannst du mir dazu etwas sagen?
Ich möchte im weiteren Verlauf die Datei später wieder in meine Funktion einfügen daher sollten es die gleichen Werte wie zuvor sein die Matlab generiert hat.
Code:
function Fenster = importfile1(filename, startRow, endRow)
%IMPORTFILE1 Import numeric data from a text file as a matrix.
% Example: % Fenster = importfile1('Fenster.csv');
%
%% Initialize variables.
delimiter = ',';
if nargin<=2
startRow = 2;
endRow = inf;
end
%% Format string for each line of text: % column1: double (%f) % column2: double (%f) % column3: double (%f) % column4: double (%f) % column5: double (%f) % For more information, see the TEXTSCAN documentation.
formatSpec = '%f%f%f%f%f%[^\n\r]';
%% 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, 'HeaderLines', startRow(1)-1, 'ReturnOnError', false);
for block=2:length(startRow) frewind(fileID);
dataArrayBlock = textscan(fileID, formatSpec, endRow(block)-startRow(block)+1, 'Delimiter', delimiter, '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.
Hallo Harald,
das Problem wurde gelöst. Ich habe es anstatt csv in txt abgespeichert.
Jetzt besteht bei meiner gestellten Frage nur noch ein Problem:
Abschließend möchte ich nur noch die Daten einer Datei anhängen.
Es sind 5 Spalten. Jedoch schreibt er mir mit diesem Befehl alle Daten hintereinander anstatt in Spalten.
Die neuen Daten der alten Datei hinzuzufügen.
Zitat:
fid=fopen('Fenster.txt', 'a+')
fprintf(fid,'%f,%f,%f,%f,%f\n', Tabelle aus Workspace);
fclose(fid)
Fehler: Number of columns on line XY of ASCII file Fenster.txt must be the same as
previous lines.
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.