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

Einlesen von Textdateien aus verschiedenen Ordnern

 

juleswinfield
Forum-Newbie

Forum-Newbie


Beiträge: 4
Anmeldedatum: 29.09.08
Wohnort: ---
Version: R2006b
     Beitrag Verfasst am: 29.09.2008, 13:35     Titel: Einlesen von Textdateien aus verschiedenen Ordnern
  Antworten mit Zitat      
Hallo!

Bin absoluter Neuling in Sachen Matlab und verzweifelt bemüht,
ein Skript zu schreiben, das folgendes ermöglicht:
Ein Ordner mit ca. 240 Unterordnern soll ausgelesen werden. Die Unterordner beinhalten jeweils ein *.mos file, mit 2 Zeilen Text. Die 2. Zeile besitzt 3 Werte, jeweils in eckiger Klammer befindlich und durch Kommata getrennt. Diese Werte sollen ausgelesen werden und in Excel übersichtlich jeweils untereinander dargestellt werden.

Hauptordner: Werte
Unterordner. Werte\Erg45.100_38.200
Dateien in den Unterordnern heißen alle: messung.mos

Mit folgendem Skript hab ich es schonmal geschafft, eine Datei so auszulesen, dass meine 3 in der Datei befindlichen Werte in Excel sauber erscheinen:
Code:

fid=fopen('messung.mos');
fgetl(fid);
line=fgetl(fid);
kommata=strfind(line,',');

charA1=line(2:kommata(1)-1);
charB1=line(kommata(1)+1:kommata(2)-1);
charC1=line(kommata(2)+1:kommata(2)+16);

A1=str2double(charA1);
B1=str2double(charB1);
C1=str2double(charC1);

xlswrite('d.xls',[A1 B1 C1])
 

Was muß gemacht werden, das dies für alle 240 dateien automatisch geschieht?
Bin über jede Hilfe erfreut,
Grüße, Jules

edit by steve: Code-Umgebung ergänzt! Bitte zukünftig selbstständig formatieren.
Danke.
Private Nachricht senden Benutzer-Profile anzeigen


steve
Ehrenmitglied

Ehrenmitglied



Beiträge: 2.022
Anmeldedatum: 03.09.07
Wohnort: Wien
Version: R2023b
     Beitrag Verfasst am: 29.09.2008, 13:59     Titel:
  Antworten mit Zitat      
Moin,

gesetzt den Fall das alle Unterordner mit "Erg" anfangen:
Code:

pathstr = dir('Erg*');
for k=1:numel(pathstr)
    fid=fopen(fullfile(pathstr(k).name,'messung.mos'));
    ...
end
 


Gruß
Alex
_________________

>> I told me to.

____________________________________
Matlab Cheat Sheet
goMatlab-Knigge - dran gehalten?!
Schon in den FAQ gesucht?
Ist vielleicht bei den Skripten oder den Tutorials was für dich dabei?
Private Nachricht senden Benutzer-Profile anzeigen
 
juleswinfield
Themenstarter

Forum-Newbie

Forum-Newbie


Beiträge: 4
Anmeldedatum: 29.09.08
Wohnort: ---
Version: R2006b
     Beitrag Verfasst am: 29.09.2008, 16:02     Titel:
  Antworten mit Zitat      
Hallo Alex/Steve,

danke für die schnelle Hilfe. er scheint jetzt wirklich auf die Ordner zuzugereifen.
Jedoch überschreibt er die erste Zeile in Excel solange, bis schließlich der Inhalt des letzten Ordners erscheint. Wie kann ich ihm sagen, das er die Werte des neuen Unterordners immer in die nächste Zeile schreibt?

Vielen Dank schon einmal..
Grüße, Jules
Private Nachricht senden Benutzer-Profile anzeigen
 
steve
Ehrenmitglied

Ehrenmitglied



Beiträge: 2.022
Anmeldedatum: 03.09.07
Wohnort: Wien
Version: R2023b
     Beitrag Verfasst am: 29.09.2008, 16:10     Titel:
  Antworten mit Zitat      
Dazu gibt es in der xlswrite-Funktion die Möglichkeit den Bereich im xls-file vorzugeben:
Code:

xlswrite('d.xls',[A1 B1 C1],['A' num2str(k)]);
 


Gruß
Alex
_________________

>> I told me to.

____________________________________
Matlab Cheat Sheet
goMatlab-Knigge - dran gehalten?!
Schon in den FAQ gesucht?
Ist vielleicht bei den Skripten oder den Tutorials was für dich dabei?
Private Nachricht senden Benutzer-Profile anzeigen
 
juleswinfield
Themenstarter

Forum-Newbie

Forum-Newbie


Beiträge: 4
Anmeldedatum: 29.09.08
Wohnort: ---
Version: R2006b
     Beitrag Verfasst am: 30.09.2008, 10:52     Titel:
  Antworten mit Zitat      
Hallo Alex!

Mit dieser Funktion erstellt er mir jedesmal ein neues excel worksheet für die Werte einer Datei. Weißt du ob es möglich ist, ihm mitzuteilen dass er mir in ein einziges worksheet untereinander die Werte auflistet?

Danke und Grüße,
Jules
Private Nachricht senden Benutzer-Profile anzeigen
 
steve
Ehrenmitglied

Ehrenmitglied



Beiträge: 2.022
Anmeldedatum: 03.09.07
Wohnort: Wien
Version: R2023b
     Beitrag Verfasst am: 30.09.2008, 11:33     Titel:
  Antworten mit Zitat      
Komisch...

und folgendes?
Code:
xlswrite('d.xls',[A1 B1 C1],1,['A' num2str(k)]);

_________________

>> I told me to.

____________________________________
Matlab Cheat Sheet
goMatlab-Knigge - dran gehalten?!
Schon in den FAQ gesucht?
Ist vielleicht bei den Skripten oder den Tutorials was für dich dabei?
Private Nachricht senden Benutzer-Profile anzeigen
 
juleswinfield
Themenstarter

Forum-Newbie

Forum-Newbie


Beiträge: 4
Anmeldedatum: 29.09.08
Wohnort: ---
Version: R2006b
     Beitrag Verfasst am: 30.09.2008, 12:42     Titel:
  Antworten mit Zitat      
Yesss!!!

Fabelhaft, jetzt tut ers. Tausend, nein Millionen Dank:-)

Grüße und einen wunderschönen Tag noch,
Jules
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 - 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.