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

Aus Dateinamen einen Variablen Namen erzeugen

 

neuer_User
Forum-Newbie

Forum-Newbie


Beiträge: 1
Anmeldedatum: 12.09.13
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 12.09.2013, 15:27     Titel: Aus Dateinamen einen Variablen Namen erzeugen
  Antworten mit Zitat      
Hallo Forum,

ich quäle mich jetzt seit Tagen mit einem bestimmt sehr einfachen Problem herum. Sad

Es geht um folgendes:
Ich habe einen Ordner in dem einige .csv-Dateien liegen, nennen wir sie Datei_abc, Datei_cde, ...Datei_xyz.csv.
Diese Dateien möchte ich über eine Schleife eingelesen, wobei die Data-Arrays dann so heissen sollen wie die Datei aus der sie eingelesen wurden.
Später sollen dann die einzelnen Spalten der Variablen zu einer Matrix zusammengesetzt und nach Excel exportiert werden (letzteres ist jedoch nicht Bestandteil der Frage sondern nur Zusatzinfo).

Folgendes habe ich mir Überlegt:
Code:

files = dir('C:\Users\Numeric\Desktop\test\MCA'); % Angabe des Ordners
 names = {files.name}; % Einlesen der Dateinamen im Ordner
 delimiter = ',';
 startRow = 5;
 endRow = 104;
Anzahl=size(names,2); % Auslesen der Anzahl der eingelesenen Dateinamen ( steht in Spalte 2)
for k=3:Anzahl  % Beginn Schleife
    filename_in =fullfile('C:\Users\Numeric\Desktop\test\MCA', names{k});
    formatSpec = '%f%f%f%f%f%f%f%f%f%f%f%f%f%f%f%f%f%[^\n\r]';
    fileID = fopen(filename_in,'r');
    textscan(fileID, '%[^\n\r]', startRow-1, 'ReturnOnError', false);
    dataArray = textscan(fileID, formatSpec, endRow-startRow+1, 'Delimiter', delimiter, 'EmptyValue' ,NaN,'ReturnOnError', false);
    fclose(fileID);

    % Es soll für jede Datei ein dataarray erzeugt werden, das genau so benannt ist wie die Datei selbst
    % noch schöner wäre es, wenn das .csv im der Namen nicht enthalten ist, aber das ist nicht so wichtig
C = [names{k}];  % In C soll der aktuelle Dateiname gespeichert werden
C = dataArray{:,k}; % Es soll ein Data-Array erzeugt werden, dass genauso heisst wie die aktuelle Datei

end  % Ende Schleife
 



Hat jemand eine Idee wie ich das Problem gelöst kriege?
Vielen Dank und Grüße
Dominik
Private Nachricht senden Benutzer-Profile anzeigen


denny
Supporter

Supporter



Beiträge: 3.853
Anmeldedatum: 14.02.08
Wohnort: Ulm
Version: R2012b
     Beitrag Verfasst am: 12.09.2013, 15:35     Titel:
  Antworten mit Zitat      
Hallo

nehme doch STRUCT dazu. Über Dynamische Felder kannst du deine Werte dort ansprechen/ablegen. Das ist leichter zu managen, als mehrere Dynamische Variablen


Code:

S.('variable1') =10;
S.('variable2') =12;

varnames = fieldnames(S);

for k=1:length(varnames)
  fprintf('%s = %d\n', varnames{k},S.(varnames{k}))  
end
 


edit: nehme REGEXPREP um Fileextention zu entfernen
Code:



name_ohne_csv= regexprep(names{k},'\.csv','')

S.(name_ohne_csv) = daten;

 


Zuletzt bearbeitet von denny am 12.09.2013, 15:41, insgesamt 2-mal bearbeitet
Private Nachricht senden Benutzer-Profile anzeigen
 
Super8film
Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 57
Anmeldedatum: 13.06.12
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 12.09.2013, 15:36     Titel:
  Antworten mit Zitat      
Code:
name = 'Datei_abc' ;
values = [0:200];

assignin('base', name , values)


sowas?
Private Nachricht senden Benutzer-Profile anzeigen
 
denny
Supporter

Supporter



Beiträge: 3.853
Anmeldedatum: 14.02.08
Wohnort: Ulm
Version: R2012b
     Beitrag Verfasst am: 12.09.2013, 15:45     Titel:
  Antworten mit Zitat      
Super8film hat Folgendes geschrieben:
Code:
name = 'Datei_abc' ;
values = [0:200];

assignin('base', name , values)


sowas?


Das sollte nach Möglichkeit vermieden werden, nicht Debuggbar, Fehleranfällig, Schwer zu Managen, Unlesbar.
Also man hat zum Auswahl bessere Alternativen, wie Structs mit Dynamischen Feldern oder Cell Arrays
Private Nachricht senden Benutzer-Profile anzeigen
 
Super8film
Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 57
Anmeldedatum: 13.06.12
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 12.09.2013, 15:57     Titel:
  Antworten mit Zitat      
Zitat:
Das sollte nach Möglichkeit vermieden werden, nicht Debuggbar, Fehleranfällig, Schwer zu Managen, Unlesbar.


Also ich habe das öfters so gemacht um klar zu zeigen, wo ich welches Produkt habe. Finde eher, dass man bei so Structs sich sehr schnell Fehler reinbaut...
aber ich werde deinen rat berücksichtigen... selten angewendet sowas.. danke für den tipp
Private Nachricht senden Benutzer-Profile anzeigen
 
denny
Supporter

Supporter



Beiträge: 3.853
Anmeldedatum: 14.02.08
Wohnort: Ulm
Version: R2012b
     Beitrag Verfasst am: 12.09.2013, 16:25     Titel:
  Antworten mit Zitat      
Super8film hat Folgendes geschrieben:
Zitat:
Das sollte nach Möglichkeit vermieden werden, nicht Debuggbar, Fehleranfällig, Schwer zu Managen, Unlesbar.


Also ich habe das öfters so gemacht um klar zu zeigen, wo ich welches Produkt habe. Finde eher, dass man bei so Structs sich sehr schnell Fehler reinbaut...
aber ich werde deinen rat berücksichtigen... selten angewendet sowas.. danke für den tipp



Die Frage ist natürlich, will man die Daten dann einschließend weiterverarbeiten, wie im Falle des Threaderstellers. Er möchte ja die Matrizen zusammensetzen, und weiter in Excel diese abspeichern. Hier ist besser eine Variable als 100 Variable. Das nämlich vereinfacht den Code.
Private Nachricht senden Benutzer-Profile anzeigen
 
markuman
Forum-Guru

Forum-Guru


Beiträge: 320
Anmeldedatum: 14.12.12
Wohnort: ---
Version: 2013a/2013b, Octave 3.6.4, 3.7.7
     Beitrag Verfasst am: 12.09.2013, 22:30     Titel:
  Antworten mit Zitat      
denny hat Folgendes geschrieben:


Code:

S.('variable1') =10;
S.('variable2') =12;

varnames = fieldnames(S);

for k=1:length(varnames)
  fprintf('%s = %d\n', varnames{k},S.(varnames{k}))  
end
 



hm, das versteh ich nicht. Das printed doch lediglich
variable1 = 10
variable2 = 12
und variable1 und variable2 existieren nicht im workspace.
_________________

DIY OR DIE Cool

entropie=char(floor(94*rand(1, round(100.*rand)) + 32))
https://github.com/markuman
Private Nachricht senden Benutzer-Profile anzeigen
 
Winkow
Moderator

Moderator



Beiträge: 3.842
Anmeldedatum: 04.11.11
Wohnort: Dresden
Version: R2014a 2015a
     Beitrag Verfasst am: 12.09.2013, 23:18     Titel:
  Antworten mit Zitat      
Zitat:
und variable1 und variable2 existieren nicht im workspace.

nein aber S.variable1
so stehts ja auch im code
_________________

richtig Fragen
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.