WICHTIG: Der Betrieb von goMatlab.de wird privat finanziert fortgesetzt. - Mehr Infos...

Mein MATLAB Forum - goMatlab.de

Mein MATLAB Forum

 
Gast > Registrieren       Autologin?   

Partner:




Forum
      Option
[Erweitert]
  • Diese Seite per Mail weiterempfehlen
     


Gehe zu:  
Neues Thema eröffnen Neue Antwort erstellen

Ergebnisse einer bestehenden Excel Datei hinzufügen

 

Harald
Forum-Meister

Forum-Meister


Beiträge: 24.448
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 15.06.2018, 09:52     Titel:
  Antworten mit Zitat      
Hallo,

load würde ich an sich nur für .mat-Dateien verwenden. Ansonsten readtable oder textscan.

Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen


ilmiomondo
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 39
Anmeldedatum: 18.05.18
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 15.06.2018, 15:03     Titel:
  Antworten mit Zitat      
Hallo harald,
fileID = fopen('filename.csv')
A = textscan(fileID','%f %f %f %f %f');

funktioniert leider nicht.
ich tippe darauf das meine formatspec falsch gewählt sind?
Kann mir jemand dabei helfen?

Grüße

Zuletzt bearbeitet von ilmiomondo am 15.06.2018, 15:07, insgesamt einmal bearbeitet
Private Nachricht senden Benutzer-Profile anzeigen
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.448
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 15.06.2018, 15:05     Titel:
  Antworten mit Zitat      
Hallo,

du musst die Datei zunächst öffnen.
Bitte auch mal die Dokumentation der Funktionen lesen!!

Zudem musst du die erste Zeile getrennt einlesen oder überspringen.

Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen
 
ilmiomondo
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 39
Anmeldedatum: 18.05.18
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 15.06.2018, 15:08     Titel:
  Antworten mit Zitat      
Hallo harald,
hatte das vergessen hinzuzufügen:

fileID = fopen('filename.csv')
A = textscan(fileID','%f %f %f %f %f');

funktioniert leider nicht.
ich tippe darauf das meine formatspec falsch gewählt sind?
Kann mir jemand dabei helfen?

Grüße

hab es :
fileID = fopen('filename.csv')
A = textscan(fileID,'%f %f %f %f %f','Delimiter',',');
fclose(fileID);
Private Nachricht senden Benutzer-Profile anzeigen
 
ilmiomondo
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 39
Anmeldedatum: 18.05.18
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 15.06.2018, 16:29     Titel:
  Antworten mit Zitat      
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

%% Close the text file.
fclose(fileID);

%% 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
dataArray = cellfun(@(x) num2cell(x), dataArray, 'UniformOutput', false);
Fenster = [dataArray{1:end-1}];

filename = 'Fenster.csv';
F = Fenster;
cd('C:\Users\\Desktop\Daten')
csvwrite(filename,F)


Grüße
Private Nachricht senden Benutzer-Profile anzeigen
 
ilmiomondo
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 39
Anmeldedatum: 18.05.18
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 18.06.2018, 10:37     Titel:
  Antworten mit Zitat      
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.
Private Nachricht senden Benutzer-Profile anzeigen
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.448
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 18.06.2018, 18:43     Titel:
  Antworten mit Zitat      
Hallo,

Zitat:
Jedoch schreibt er mir mit diesem Befehl alle Daten hintereinander anstatt in Spalten.

Verstehe ich nicht. Was soll der Unterschied zwischen "hintereinander" und "in Spalten" sein?

Zitat:
Fehler: Number of columns on line XY of ASCII file Fenster.txt must be the same as previous lines.

Mehr als die Fehlermeldung zu übersetzen kann ich hier leider mangels Informationen über die Datei und die anzufügenden Daten nicht tun.

Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen
 
Neues Thema eröffnen Neue Antwort erstellen

Gehe zu Seite Zurück  1, 2

Einstellungen und Berechtigungen
Beiträge der letzten Zeit anzeigen:

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
.





 Impressum  | Nutzungsbedingungen  | Datenschutz | FAQ | goMatlab RSS Button RSS

Hosted by:


Copyright © 2007 - 2024 goMatlab.de | Dies ist keine offizielle Website der Firma The Mathworks

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.