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

Möchte ein Excel Sheet einlesen, Fehlermeldung ist ab unkla

 

Jaeger
Forum-Newbie

Forum-Newbie


Beiträge: 2
Anmeldedatum: 13.02.11
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 13.02.2011, 14:52     Titel: Möchte ein Excel Sheet einlesen, Fehlermeldung ist ab unkla
  Antworten mit Zitat      
Hey,
bin noch unerfahren mit matlab und habe grad dieses kleine Programm geschrieben, in dem ich eine Excel datei so einlesen will:
-Anzahl der Sheets bestimmen
-sheets einzeln in ein array packen


Code:
[typ, desc] = xlsfinfo('v-Dias.xls');                                      
a=size(desc);
i=a(2);
b=cell(1,(a(2)));
while i~=0
   
   b(i)= xlsread('v-Dias.xls','desc(i)');
   i= i-1;
end
 

Dabei kommt nun die Fehlermeldung:
Code:
Warning: Could not start Excel server for import, 'basic' mode will be used.
Refer to HELP XLSREAD for more information.
> In xlsread at 176
  In Simu at 10
??? Error using ==> xlsread at 234
XLSREAD unable to read sheet desc(i).
Requested sheet: 'desc(i)' not found.


Error in ==> Simu at 10
   b(i)= xlsread('v-Dias.xls','desc(i)');]
 


Excel ist nicht auf dem rechner installiert, verursacht das auch den zweiten Fehler ?
Private Nachricht senden Benutzer-Profile anzeigen


Sco
Forum-Meister

Forum-Meister


Beiträge: 699
Anmeldedatum: 15.08.10
Wohnort: Dundee
Version: 2008a, 2010a
     Beitrag Verfasst am: 13.02.2011, 15:25     Titel:
  Antworten mit Zitat      
Hallo,

1. Excel muss auf dem PC installiert sein, sonst funktioniert es nicht, da Matlab eine Excel Instanz über eine ActiveX-Verbindung öffnet und dann die Daten holt.

2. foldende Codezeile ist inkorrekt:
Code:

b(i)= xlsread('v-Dias.xls','desc(i)');
ersetzen durch
b{i}= xlsread('v-Dias.xls',desc{i}); % beachte die geschweiften Klammern bei "b" und "i"
 

Um auf den Inhalt einer Zelle zuzugreifen musst du die geschweiften Klammern verwenden.
Eine etwas kürzere Variante deines Codes wäre z.B.:
Code:

[typ, desc] = xlsfinfo('v-Dias.xls');                                      
a = size(desc,2); % dirkte Angabe der gesuchten Dimension
b = cell(1,a);
for i = 1:a
      b{i}= xlsread('v-Dias.xls',desc{i});
end
 


MFG

Sco
Private Nachricht senden Benutzer-Profile anzeigen
 
Jaeger
Themenstarter

Forum-Newbie

Forum-Newbie


Beiträge: 2
Anmeldedatum: 13.02.11
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 13.02.2011, 15:38     Titel:
  Antworten mit Zitat      
Hallo Sco,
Danke für die schnelle Antwort und den verbesserten code.

beste grüße
Jaeger
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.