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

txt file einlesen ohne enthaltene Zeichen

 

code88
Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 91
Anmeldedatum: 06.02.08
Wohnort: Meinisberg
Version: MATLAB Version 7.8.0.347 (R2009a)
     Beitrag Verfasst am: 28.05.2009, 17:46     Titel: txt file einlesen ohne enthaltene Zeichen
  Antworten mit Zitat      
Ich habe ein txt file das ich gerne Zeilenweise einlesen will.

Das txt file hat folgende Struktur:

"Anlage";;"0";"0";"0";"0"
"Messstelle";;"1";"5";"10";"13"
"Kommentar";;"Isttemperatur";"Istfeuchte";"Solltemperatur";"Sollfeuchte"
"Sensor";;"MV01";"MV11";"SV01";"SV11"
"Einheit";;"°C";"%";"°C";"%"
"Grenzwerte";;;;;
;;;;;

"30.04.2009";"16:27:38";21;26,1;-29;
"30.04.2009";"16:27:48";20,3;22,5;-29;
"30.04.2009";"16:27:58";19,5;19,6;-29;
"30.04.2009";"16:28:08";18,8;17,4;-29;

ein Auszug aus meinem Code:
Code:

fid=fopen(Datenfiles{k},'r');% file öffnen
vec = textscan(fid,'%s',8,'delimiter','\n');% Header einlesen
vec = textscan(fid,'%s %s %n %n %n %n',1,'endofline',';');% erste Zeile einlesen
 

Matlab liest dann in der ersten Cell "30.04.2009"" ein und weiter stimmt nichts mehr.
Nun ich möchte die Anführungszeichen gar nicht einlesen sondern nur das Datum und die Uhrzeit zwischendrinn.

Hat mir da jemand eine Lösung?
Private Nachricht senden Benutzer-Profile anzeigen


code88
Themenstarter

Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 91
Anmeldedatum: 06.02.08
Wohnort: Meinisberg
Version: MATLAB Version 7.8.0.347 (R2009a)
     Beitrag Verfasst am: 29.05.2009, 09:20     Titel:
  Antworten mit Zitat      
Wenn ich das Datum statt als string nur die einzelnen charakter einlese zeigt sich, dass Matlab das Semikolon nicht erkannt.

Code:

vec = textscan(fid,'%12c %10c %n %n %n %n',1,'endofline',';');
 


ergibt dann

'"30.04.2009"' ';"16:27:38' [] [] [] []

Zuletzt bearbeitet von code88 am 29.05.2009, 10:19, insgesamt einmal bearbeitet
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.05.2009, 09:50     Titel:
  Antworten mit Zitat      
Moin,

probier es mal, wenn du aus dem 'endofline' ein 'delimiter' machst.

Code:
vec = textscan(fid,'%12c %10c %n %n %n %n',1,'delimiter',';');


Die '"' bekommst du weg, in dem du STRREP verwendest:
Code:
vec = strrep(vec,'"','');


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
 
code88
Themenstarter

Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 91
Anmeldedatum: 06.02.08
Wohnort: Meinisberg
Version: MATLAB Version 7.8.0.347 (R2009a)
     Beitrag Verfasst am: 29.05.2009, 10:13     Titel:
  Antworten mit Zitat      
Super das funktioniert danke.
Nun muss ich nur noch das Komma als Trennzeichen für die Dezimalstelle bei Matlab definieren. Matlab verwendet ja dazu ein Punkt und im txt File sind leider Kommas.
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.05.2009, 10:50     Titel:
  Antworten mit Zitat      
Die kannst du ebenfalls ersetzten:
Code:
vec = strrep(vec,',','.');

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
 
code88
Themenstarter

Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 91
Anmeldedatum: 06.02.08
Wohnort: Meinisberg
Version: MATLAB Version 7.8.0.347 (R2009a)
     Beitrag Verfasst am: 29.05.2009, 15:48     Titel:
  Antworten mit Zitat      
Ok ich habe nun

Code:

vec = textscan(fid,'%12s %10s %s %s %s %s',1,'delimiter',';');
            vec{1} = strrep(vec{1},'"','');% es könnte sicher der ganze Vektor auf einmal durchsucht und bearbeitet werden.
            vec{2} = strrep(vec{2},'"','');
            vec{3} = strrep(vec{3}, ',', '.');
            vec{4} = strrep(vec{4}, ',', '.');
            vec{5} = strrep(vec{5}, ',', '.');
            vec{6} = strrep(vec{6}, ',', '.');
 


so kann ich die Daten in ein Cell Array einlesen, "" löchen und , mit . ersetzen.

Natürlich sollen daraus dann numbers entstehen und dann in einer Grafik dargestellt werden. Leider funktioniert die Konvertierung zu numbers nicht habe schon cell2str versucht um dann mit einem string weiterzuarbeiten aber auch die str2num und str2double funktionieren nicht.

Weiter frage ich mich wie ich dann das Datum was ein string ist in die Grafik kriege.
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.