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

csv Datei einlesen und Länge erkennen

 

ChristopherME
Forum-Anfänger

Forum-Anfänger


Beiträge: 14
Anmeldedatum: 06.08.15
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 17.10.2016, 19:06     Titel: csv Datei einlesen und Länge erkennen
  Antworten mit Zitat      
Hallo,

ich möchte mehrere csv Dateien einlesen und 1 Vektor erstellen.
Anstatt der 5000 möchte ich jedoch, dass Matlab die Länge der Spalte erkennt und diese automatisch nimmt.

Die Suchfunktion hat leider nicht geholfen.
Code:

filename = 'csvlist.dat';
V1 = csvread('01.csv',4,1,[4,1,5000,1]);
 


Ein weiteres Problem ist, dass ich noch weitere Dateien habe. 01 bis 05.csv und entsprechend die Vektoren V1 bis V5 erstellen möchte. Leider reichen meine Fähigkeiten dafür nicht aus :/ Wäre für Tipps und/oder Lösungen sehr verbunden.

Danke im Voraus
Private Nachricht senden Benutzer-Profile anzeigen


Harald
Forum-Meister

Forum-Meister


Beiträge: 24.499
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 17.10.2016, 20:16     Titel:
  Antworten mit Zitat      
Hallo,

Funktionen wie textscan bieten mehr Flexibilität.

Code:
fid = fopen('01.csv');
data = textscan(fid, '%f %*[^\n]');
V = data{1};


Für mehrere Dateien bietet sich eine for-Schleife an:
Code:
for k = 1:6
  fid = fopen(['0' num2str(k) '.csv']);
  data = textscan(fid, '%f %*[^\n]');
  V{k} = data{1};
end

Variablen durchnummerieren ist keine gute Idee, siehe diverse Threads dazu. Besser sind Cell Arrays (wie im Vorschlag verwendet).

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

Forum-Anfänger

Forum-Anfänger


Beiträge: 14
Anmeldedatum: 06.08.15
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 18.10.2016, 08:35     Titel:
  Antworten mit Zitat      
danke für die schnelle Hilfe.

Das Problem besteht darin, dass die csv Dateien mit Kommata als Trennzeichen erstellt wurden. Meiner Recherche nach funktioniert dabei nur csvread ?

Wie kann ich (als sehr unerfahren mit MatLab) Dateinamen in die Schleife einbinden?
Das zB die Dateien "Daten_01.csv" bis 09 heißen und ich die Werte der 3 Spalte alle in eine Matrix der Größe nx9 bringe?

Edit:

Habe es jetzt folgendermaßen gelöst:

Code:
clear all
filename = 'csvlist.dat';


for k = 1:5
Kraft1 = csvread(['serie_a_0' num2str(k) '.csv'],4,1,[4,1,800,1]);
Weg1 = csvread(['serie_a_0' num2str(k) '.csv'],4,3,[4,3,800,3]);
Weg1 = Weg1 - min(Weg1);
end


Ich möchte jedoch noch eine große Matrix erstellen, in der "Kraft1" die erste Spalte belegt, Kraft2 die 2te usw.
Analog würde ich dies dann auch für "Weg" tun. Wie kann ich das realisieren? Smile
Private Nachricht senden Benutzer-Profile anzeigen
 
Jan S
Moderator

Moderator


Beiträge: 11.057
Anmeldedatum: 08.07.10
Wohnort: Heidelberg
Version: 2009a, 2016b
     Beitrag Verfasst am: 18.10.2016, 10:25     Titel:
  Antworten mit Zitat      
Hallo ChristopherME,

Wenn Du '01' im Namen brauchst, hilft dies:
Code:
FileName = fullfile(Folder, sprintf('Daten_%02d.csv', k));

Das fügt die führende 0 automatisch ein ohbne dass es ab dem 10. File Probleme gibt.

"Kraft2" ist grundsätzlich eine schlechte Idee. Indices in Namen von Variablen zu verstecken wird hier nahazu täglich diskutiert: Das erfordert komplizierte Methoden und noch kompliziertere, wenn man später auf die Variablen zugreifen möchte.
Die richtige Methode Daten zu indizieren ist die Verwendung eines Index :-)
Falls alle Arrays die gleiche Größe haben, nimmt man ein mehrdimensionales Array, falls sie unterschiedliche Größe haben ein Cell-Array. Also:
Code:
Kraft(:, :, 2)
% Oder
Kraft{2}

Dann ist der Zugriff per Schleife einfach und man muss nicht mit Variablen-Namen jonglieren. Siehe dazu hunderte Threads zum Stichwort "eval".

Gruß, Jan
Private Nachricht senden Benutzer-Profile anzeigen
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.499
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 18.10.2016, 20:06     Titel:
  Antworten mit Zitat      
Hallo,

Zitat:
Das Problem besteht darin, dass die csv Dateien mit Kommata als Trennzeichen erstellt wurden. Meiner Recherche nach funktioniert dabei nur csvread ?

Dezimal- oder Spaltentrennzeichen?
Das Spaltentrennzeichen kann man bei textscan explizit angeben.
Mit Komma als Dezimaltrennzeichen kommt auch csvread nicht klar.

Zitat:
Wie kann ich (als sehr unerfahren mit MatLab) Dateinamen in die Schleife einbinden?

Solange die Dateianzahl nicht zweistellig wird: haargenau so, wie ich es vorgeschlagen hatte. Wenn vor der 0 in den tatsächlichen Dateinamen noch etwas steht, musst du das eben vorne anfügen.
Wenn du die echten Dateinamen angegeben hättest, hätte ich das Beispiel darauf ausgelegt. Leider kann man eben immer nur mit den Informationen arbeiten, die zur Verfügung gestellt werden.

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



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 - 2025 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.