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

xlsread und Variable in Range

 

k@tze
Forum-Anfänger

Forum-Anfänger


Beiträge: 29
Anmeldedatum: 27.12.10
Wohnort: ---
Version: 7.9.0 R2009b
     Beitrag Verfasst am: 26.05.2011, 15:48     Titel: xlsread und Variable in Range
  Antworten mit Zitat      
Hallo,

wenn ich den Bereich B2:D2 aus einem Excelsheet auslesen möchte, dann geht das z. B. so:

Code:
x=xlsread(file,1,'B2:D2');


Wie kann ich aber meine Werte Auslesen, wenn die Range in der Spalte je nach Laufvariable j variiert? D. h. ich möchte so etwas wie beim Matrixaufruf:

Code:
num(2,2:j+1)


Problem ist nun, dass die Spaltenangabe bei xlsread in Form der Buchstaben erfolgt. Mit dem num2str Befehl ist das Gleiche mit Zeilen statt Spalten unproblematisch.

Hoffe das Problem ist verständlich.

Gruß,
k@tze
Private Nachricht senden Benutzer-Profile anzeigen


denny
Supporter

Supporter



Beiträge: 3.853
Anmeldedatum: 14.02.08
Wohnort: Ulm
Version: R2012b
     Beitrag Verfasst am: 26.05.2011, 17:47     Titel:
  Antworten mit Zitat      
Hallo
dann brauchst dazu so was wie Konverter:
http://www.mathworks.com/matlabcent.....2-excel-column-conversion

aber das muss für deinen Fall noch anschreiben.
Private Nachricht senden Benutzer-Profile anzeigen
 
k@tze
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 29
Anmeldedatum: 27.12.10
Wohnort: ---
Version: 7.9.0 R2009b
     Beitrag Verfasst am: 30.05.2011, 09:30     Titel:
  Antworten mit Zitat      
Hallo denny,

danke für den Konverter.

Code:
ExcelCol(7)


liefert bspw. 'G'. Für den xlsread Befehl benötige ich jedoch G, also ohne ''. Kann man das auch umwandeln?

Deinen letzten Satz verstehe ich leider gar nicht.

Gruß,
k@tze[/code]
Private Nachricht senden Benutzer-Profile anzeigen
 
denny
Supporter

Supporter



Beiträge: 3.853
Anmeldedatum: 14.02.08
Wohnort: Ulm
Version: R2012b
     Beitrag Verfasst am: 30.05.2011, 09:38     Titel:
  Antworten mit Zitat      
Hallo


Sorry ich meinte natürlich, dass du den Code noch für deinen Fall besser anpassen musst.

Zitat:

danke für den Konverter.

Code:
ExcelCol(7)


liefert bspw. 'G'. Für den xlsread Befehl benötige ich jedoch G, also ohne ''. Kann man das auch umwandeln?

Die Funktion liefert einen CELL-Array. Also umwandeln kannst du z.B mit CHAR oder du arbeitest mit geschweiften Klammern:

Code:

res= ExcelCol(7)

char(res)

res{1}
 
Private Nachricht senden Benutzer-Profile anzeigen
 
k@tze
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 29
Anmeldedatum: 27.12.10
Wohnort: ---
Version: 7.9.0 R2009b
     Beitrag Verfasst am: 30.05.2011, 09:55     Titel:
  Antworten mit Zitat      
Achso, ja da hast du Recht!

Code:
x1=xlsread(file,1,'char(ExcelCol(2))2');
res= ExcelCol(7);
x2=xlsread(file,1,'res{1}2');


Für x1 und x2 ergibt sich jeweils der Fehler "Data range is invalid.". Benötige ich jetzt noch etwas wie char2str??
Private Nachricht senden Benutzer-Profile anzeigen
 
tompie
Forum-Guru

Forum-Guru


Beiträge: 260
Anmeldedatum: 19.09.07
Wohnort: München
Version: immer alles
     Beitrag Verfasst am: 30.05.2011, 11:40     Titel:
  Antworten mit Zitat      
Hallo,

Deine String-Verkettungen sind nicht korrekt. Du musst schreiben

Code:
x1=xlsread(file,1,[char(ExcelCol(2)) '2']);
res= ExcelCol(7);
x2=xlsread(file,1,[res{1} '2']);



Gruß tompie
Private Nachricht senden Benutzer-Profile anzeigen
 
k@tze
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 29
Anmeldedatum: 27.12.10
Wohnort: ---
Version: 7.9.0 R2009b
     Beitrag Verfasst am: 30.05.2011, 13:16     Titel:
  Antworten mit Zitat      
Klasse, damit funktioniert es wie gewünscht. Ich danke euch beiden!

Gruß,
k@tze
Private Nachricht senden Benutzer-Profile anzeigen
 
at0m_t0mato
Forum-Anfänger

Forum-Anfänger


Beiträge: 20
Anmeldedatum: 04.04.17
Wohnort: ---
Version: R2018b
     Beitrag Verfasst am: 15.05.2017, 00:46     Titel:
  Antworten mit Zitat      
Hallo,
ich habe diesen Thread für mein Problem gefunden.
Ich wüsste gerne noch, wie ich einen Bereich (bspw. B2:B10) auswählen kann. Das geht für mich aus den vorherigen Antworte leider nicht hervor.
Denn der Code
Code:

x1=xlsread(file,1,[char(ExcelCol(2)) '2']);
 

liefert mir ja lediglich die Zelle B2. Ich würde es gerne in etwa so machen
Code:

b = 1;
x1=xlsread(file,1,[char(ExcelCol(b)) '2'] : [char(ExcelCol(b)) '10']);
 

...doch da kommt dann verständlicher Weise nur "Data range 'B' is invalid".
Kann mir jemand sagen, wie ich es richtig schreiben müsste? Ihr würdet mir wirklich sehr helfen!

Viele Grüße
Private Nachricht senden Benutzer-Profile anzeigen
 
at0m_t0mato
Forum-Anfänger

Forum-Anfänger


Beiträge: 20
Anmeldedatum: 04.04.17
Wohnort: ---
Version: R2018b
     Beitrag Verfasst am: 15.05.2017, 11:09     Titel:
  Antworten mit Zitat      
Eine Lösung wäre folgendes:
Code:

b = 2;
x1=xlsread(file,1,[char(ExcelCol(b)) '2' ':', char(ExcelCol(b)) '10']);
 
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.