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

daten in bestimmen cellen von exel speichern

 

tupi
Forum-Anfänger

Forum-Anfänger


Beiträge: 11
Anmeldedatum: 21.03.09
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 19.06.2009, 13:58     Titel: daten in bestimmen cellen von exel speichern
  Antworten mit Zitat      
hallo, ich möche bestimmte matritzen in vorgegebene exel-zellen speichern, ich kriege das aber irgendwie nicht hin. Die numerierung der zellen soll von einer schleife
for l=1:30
abhängen

ich versuche mit dem befehl :
Code:

xlswrite('datei.xls', meinematrix,'tabelle',eval(['A' num2str(l)]));


der befehl sollte die matrix "meinematrix" in der Datei "Datei" in der Tabelle "Tabelle" ab Zelle A(l) speichern aber er erkennt dann A23 nicht falls l= 23.

Kann mir da jemand weiterhelfen?
Private Nachricht senden Benutzer-Profile anzeigen


ben
Forum-Anfänger

Forum-Anfänger


Beiträge: 28
Anmeldedatum: 21.08.08
Wohnort: Stuttgart
Version: R2007a, R2008b
     Beitrag Verfasst am: 19.06.2009, 14:18     Titel:
  Antworten mit Zitat      
Das Problem ist, dass du die Anführungszeichen für A23 nicht hast. Die Anfangszelle muss als String eingegeben werden: 'A23'.

Musst nur das eval weg lassen, dann gehts.
Code:

xlswrite('datei.xls', meinematrix, 'tabelle', ['A' num2str(l)]);
 


Gruß, Ben
Private Nachricht senden Benutzer-Profile anzeigen
 
lidogiba
Forum-Newbie

Forum-Newbie


Beiträge: 7
Anmeldedatum: 21.08.09
Wohnort: Hannover
Version: R2009a
     Beitrag Verfasst am: 21.08.2009, 13:31     Titel: Spalten hochzählen
  Antworten mit Zitat      
Hallo Zusammen,

ich greife dieses Thema mal auf, da ich eine ähnliche Frage habe.

Ich möchte Vektoren neben einander in die Spalten einer Excel-Datei schreiben. In jeder Iteration der Schleife werden zwei Vektoren produziert die ebendfals neben einander stehen sollen.
Also in A1 und B1 soll für i=1 geschrieben werden, C1 und D1 bei i=2...

Die beiden Vekoren werden einzeln durch das zweimalige Aufrufen des xlswrite Befehl geschrieben (Auch schon ein Tipp den ich in einem anderen Thread hier im Forum gefunden habe).

Nach langem Probieren bitte ich um eure Hilfe, wie kann ich den Range hochzählen? Die Schleife wird ca. 200 mal durchlaufen, also 400 Spalten. Das heißt, dass nach Z, AA und AB... folgen muss. Kann man das überhaupt automatisieren???


Ich danke euch jetzt schon für eure Hilfe.
_________________

Vieles hätte ich verstanden, wenn man es mir nicht erklärt hätte. (Stanislaw Jerzy Lec)


Aber eben nicht ALLES!!!
Private Nachricht senden Benutzer-Profile anzeigen
 
lidogiba
Forum-Newbie

Forum-Newbie


Beiträge: 7
Anmeldedatum: 21.08.09
Wohnort: Hannover
Version: R2009a
     Beitrag Verfasst am: 24.08.2009, 09:55     Titel: gut auch wenn man's selber kann
  Antworten mit Zitat      
hallo meine Lieben....
ich habe mir dann mal selber geholfen und um niemanden dumm sterben zulassen hier meine Lösung.

Vielleicht hat ja auch noch jemand Verbesserungsvorschläge, oder Tipps zu Eleganz und Geschwindigkeit.

Code:

% Zuschreibende Daten
P = [0;0;0;0;0;0;0;0;];
delta = [1;1;1;1;1;1;1;1];

j = 1;
a = 1;

% Das Alphabet
M = 'A':'Z';

for n=1:15
     
    % Ersten 26 Spalten in Exel anders:
    if j <= 26
        E = xlswrite('dat.xls',{['P' num2str(n)]},'sheet',[M(j) '1']);
        E = xlswrite('dat.xls',P,'sheet',[M(j) '2']);
        j = j+1;
        E = xlswrite('dat.xls',{['delta' num2str(n)]},'sheet',[M(j) '1']);
        E = xlswrite('dat.xls',delta,'sheet',[M(j) '2']);
        j = j+1;
   
    % Ab der 26. Spalte:
    else % j>26
        E = xlswrite('dat.xls',{['P' num2str(n)]},'sheet',[M(j-26) M(a) '1']);
        E = xlswrite('dat.xls',P,'sheet',[M(j-26) M(a) '2']);
        a = a+1;
        E = xlswrite('dat.xls',{['delta' num2str(n)]},'sheet',[M(j-26) M(a) '1']);
        E = xlswrite('dat.xls',delta,'sheet',[M(j-26) M(a) '2']);
        a = a+1;
        if a > 26
            a = 1;
            j = j+1;
        end
    end
end
 


Soweit bis jetzt, wer Anregungen hat immer raus damit. Ach und selber denken tut nicht weh Wink .

LG Britta
_________________

Vieles hätte ich verstanden, wenn man es mir nicht erklärt hätte. (Stanislaw Jerzy Lec)


Aber eben nicht ALLES!!!
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.