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

Tabelle importiert -> für Ordner automatisieren

 

Zoe401
Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 88
Anmeldedatum: 07.10.15
Wohnort: Bei Stuttgart
Version: R2015a
     Beitrag Verfasst am: 09.10.2015, 22:19     Titel: Tabelle importiert -> für Ordner automatisieren
  Antworten mit Zitat      
Hallo,

ich habe hier ein Code der mir meine Excel Tabelle einliest.
Wie kann ich das automatisieren, dass Matlab das automatisch mit allen Dateien in diesem Ordner macht?

Code:
function n = importtable(filename, startRow, endRow)
%IMPORTFILE1 Import numeric data from a text file as a matrix.
%   N = IMPORTFILE1(FILENAME) Reads data from text file FILENAME for the
%   default selection.
%
%   N = IMPORTFILE1(FILENAME, STARTROW, ENDROW) Reads data from rows
%   STARTROW through ENDROW of text file FILENAME.
%
% Example:
%   n = importfile1('123456_H131-88_n917_a30_Config01.csv', 3, 51202);
%
%    See also TEXTSCAN.

% Auto-generated by MATLAB on 2015/10/09 22:09:50

%% Initialize variables.
delimiter = ',';
if nargin<=2
    startRow = 3;
    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)
%   column6: double (%f)
%   column7: double (%f)
%   column8: double (%f)
%   column9: double (%f)
%   column10: double (%f)
%   column11: double (%f)
%   column12: double (%f)
%   column13: double (%f)
%   column14: double (%f)
%   column15: double (%f)
%   column16: double (%f)
%   column17: double (%f)
%   column18: double (%f)
% For more information, see the TEXTSCAN documentation.
formatSpec = '%f%f%f%f%f%f%f%f%f%f%f%f%f%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, 'EmptyValue' ,NaN,'HeaderLines', startRow(1)-1, 'ReturnOnError', false);
for block=2:length(startRow)
    frewind(fileID);
    dataArrayBlock = textscan(fileID, formatSpec, endRow(block)-startRow(block)+1, 'Delimiter', delimiter, 'EmptyValue' ,NaN,'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
n = table(dataArray{1:end-1}, 'VariableNames', {'B1','B2','B3','B4','B5','B6','B7','B9','B10','B11','B12','B19','B15','B17','B18','B20','Trigger','Drehzahl'});

 


Viele Grüße
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: 09.10.2015, 23:03     Titel:
  Antworten mit Zitat      
ist das die fortsetzung von dem thread? http://www.gomatlab.de/viewtopic,p,156049.html#156049
_________________

richtig Fragen
Private Nachricht senden Benutzer-Profile anzeigen
 
Zoe401
Themenstarter

Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 88
Anmeldedatum: 07.10.15
Wohnort: Bei Stuttgart
Version: R2015a
     Beitrag Verfasst am: 09.10.2015, 23:29     Titel:
  Antworten mit Zitat      
Nein ist ein anderes Thema!
das andere habe ich jetzt hinbekommen

hab ich schon wieder gegen forenregeln verstoßen?
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: 09.10.2015, 23:52     Titel:
  Antworten mit Zitat      
nein es hat sich nur nach dem gleich problem angehört. in dem anderen thread war ja auch von mehrren ordnern die rede. wenn du das andere problem lösen kontest wäre es nett wenn du das dann in den thread schreibst oder sogar auch die lösung angiebtst für nutzer die später vielleicht auf das selbe problem stoßen
_________________

richtig Fragen
Private Nachricht senden Benutzer-Profile anzeigen
 
Zoe401
Themenstarter

Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 88
Anmeldedatum: 07.10.15
Wohnort: Bei Stuttgart
Version: R2015a
     Beitrag Verfasst am: 10.10.2015, 00:07     Titel:
  Antworten mit Zitat      
ja hatte ich vor... muss aber erst mal mit meiner aufgabe fertig werden

Aber eine Idee um zu sagen mit diesem Code lade ich die Datei ein und das mache mit allen Dateien in dem Ordner hast du nicht?
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: 10.10.2015, 01:38     Titel:
  Antworten mit Zitat      
doch ich dachte blos das hast du selber schon in der anderen aufgabe implementiert. so wie jan gesagt hat mit dir etc alle daten finden und dann einfach eine schleife über die namen laufen lassen das die dann als filename in deine importfile eingesetzt werden. guck dir auch mal fullfile das könnte hilfreich sein. wenn es unterordner gibt etc dann kannst du mal im FEX nach einer lösung gucken die auch alle unterordner durchsucht. da gab es schon was.
_________________

richtig Fragen
Private Nachricht senden Benutzer-Profile anzeigen
 
Zoe401
Themenstarter

Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 88
Anmeldedatum: 07.10.15
Wohnort: Bei Stuttgart
Version: R2015a
     Beitrag Verfasst am: 12.10.2015, 10:59     Titel:
  Antworten mit Zitat      
also, das mit dem importieren klappt jetzt ganz gut!

allerdings habe ich noch das problem, dass wenn ich alle dateien importiere, er mir immer die vorherige überschreibt, sodass ich am schluss nur die letzte datei importiert habe.

Wie kann ich sagen, das er die Outputs durchnummerieren soll?

So sieht es bis jetzt aus:

Code:
csvfiles = dir('*.csv');
for allFiles = csvfiles'
    csv = importtable_test(allFiles.name, 3, inf);
end
 


Viele Grüße
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.10.2015, 11:42     Titel:
  Antworten mit Zitat      
dann musst du halt nicht immer das vorherige ergebniss überschreiben sondern jeweisl in einem eigenen eintrag speichern. das könnte man mit cell arrays machen oder mit struckts oder mit matrizen je nachdem.
Code:
for k=1:10
a{k}=einlesen.....
end

so in der art halt
_________________

richtig Fragen
Private Nachricht senden Benutzer-Profile anzeigen
 
Zoe401
Themenstarter

Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 88
Anmeldedatum: 07.10.15
Wohnort: Bei Stuttgart
Version: R2015a
     Beitrag Verfasst am: 12.10.2015, 14:12     Titel:
  Antworten mit Zitat      
Ich bekomme es einfach nicht hin, was ist denn daran falsch? (hab auch schon ein paar andere Varianten durchprobiert Sad

Code:
csvfiles = dir('*.csv');
num_files = length(csvfiles);
for allFiles = csvfiles'
end
for i = 1:num_files;
    csv = allFiles;
    csv(i) = importtable_test(allFiles.name, 3, inf);
end



Assignment between unlike types is not allowed.

oder so:

Code:
csvfiles = dir('*.csv');
num_files = length(csvfiles);
for allFiles = csvfiles'
end
for i = 1:num_files;
    csv = evalin('base',csv(i).name);
    csv{i} = importtable_test(allFiles.name, 3, inf);
end


Undefined variable "csv" or class "csv".
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.10.2015, 14:43     Titel:
  Antworten mit Zitat      
Zitat:
for allFiles = csvfiles'
end

es ist mir schleierhaft was du damit erreichen willst

Zitat:
Code:
csv = evalin('base',csv(i).name);
was soll das bringen?


Code:
csvfiles = dir('*.csv');
num_files = length(csvfiles);
for i = 1:num_files;
    csv{i} = importtable_test(csvfiles(i).name, 3, inf);
end

_________________

richtig Fragen
Private Nachricht senden Benutzer-Profile anzeigen
 
Zoe401
Themenstarter

Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 88
Anmeldedatum: 07.10.15
Wohnort: Bei Stuttgart
Version: R2015a
     Beitrag Verfasst am: 12.10.2015, 15:15     Titel:
  Antworten mit Zitat      
Is schonmal voll gut! Dankeschön!

Aber wie bekomme ich jetzt meine Variablen aus dem Cell Array in meine Workspace?
Bekomme ich das gleich hin in der Funktion oben, oder muss ich die jetzt extra noch extrahieren?
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.10.2015, 15:29     Titel:
  Antworten mit Zitat      
die sind doch alle in csv gespeichert daher ist mir deine frage nicht verständlich
_________________

richtig Fragen
Private Nachricht senden Benutzer-Profile anzeigen
 
Zoe401
Themenstarter

Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 88
Anmeldedatum: 07.10.15
Wohnort: Bei Stuttgart
Version: R2015a
     Beitrag Verfasst am: 12.10.2015, 15:45     Titel:
  Antworten mit Zitat      
Also ich habe ja jetzt durch "csv{i}" ein array erstellt indem sich alle meine tabellen csv1, csv2, csv3... befinden (Bild 1&2). Ich hätte aber gerne, dass diese Tabellen als Variable ("matrix") in meiner Workspace auftauchen. So wie es auch ist, wenn ich nur eine csv-Tabelle reinlade (Bild 3).

Also das es aussieht wie in Bild 4 nur automatisch

Bild 4.jpg
 Beschreibung:

Download
 Dateiname:  Bild 4.jpg
 Dateigröße:  242.59 KB
 Heruntergeladen:  303 mal
Bild 3.jpg
 Beschreibung:

Download
 Dateiname:  Bild 3.jpg
 Dateigröße:  140.83 KB
 Heruntergeladen:  218 mal
Bild 2.jpg
 Beschreibung:

Download
 Dateiname:  Bild 2.jpg
 Dateigröße:  204.06 KB
 Heruntergeladen:  223 mal
Bild 1.jpg
 Beschreibung:

Download
 Dateiname:  Bild 1.jpg
 Dateigröße:  180.12 KB
 Heruntergeladen:  187 mal
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.