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

xlswrit Cell Arrays

 

niniwe
Forum-Anfänger

Forum-Anfänger


Beiträge: 23
Anmeldedatum: 03.07.12
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 15.08.2012, 14:26     Titel: xlswrit Cell Arrays
  Antworten mit Zitat      
Hallo,
ich bin Matlab Anfänger und schreibe gerade ein Programm für die Uni. Dabei möchte ich mehrere Matritzen in ein Exceldokument schreiben. Ich habe gelesen, das man dafür ganz toll Cell Arrays benutzen kann. Ich hab das mal Ausprobiert aber leider schreibt er nur die Strings in das Exceldokument, nicht die Matritzen. Geht das einfach nicht oder hab ich was falsch gemacht?
Danke schon mal für eure Hilfe.
Nini

Code:

A=ones(10,15);
B=linspace(1,10,10);
C=(linspace(1,15,15))';

Cell={'Exceldokument' [] [];[] 'Längsteilung' C;'Winkelteilung' A [] ; B [] []};

xlswrite('test.xls',Cell)
 
Private Nachricht senden Benutzer-Profile anzeigen


draussen
Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 90
Anmeldedatum: 26.11.10
Wohnort: DE
Version: 2010b,2020a
     Beitrag Verfasst am: 15.08.2012, 15:46     Titel:
  Antworten mit Zitat      
Hallo,

Du versuchst in Deinem Code eine Matrize in eine Zelle in Excel zu schieben.
Wenn Du sowas schreibst:
Code:

xlswrite('test.xls',A)
 

Erscheint die Matrix A in Excel.

Mir ist nicht ganz klar wie das hinterher in Excel aussehen soll. Ich empfehle mal die Help mit dem Schlagwort "xlswrite".

MfG

Georg
_________________

Der Einäugige ist unter den Blinden der König!!!
Private Nachricht senden Benutzer-Profile anzeigen
 
niniwe
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 23
Anmeldedatum: 03.07.12
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 16.08.2012, 09:56     Titel:
  Antworten mit Zitat      
Ok, d.h. mit einem Cell-Array kann ich mein Problem also nicht lösen.

Gibt es eine andere Möglichkeit mehrere Variablen aufeinmal mit xlswrite zu schreiben?
(xlswrite1 hab ich schon ausprobiert das funktioniert nicht sehr toll wenn man den code nicht versteht und in folge dessen keine Änderungen dran vornhemen kann, aber ich bin auch für Tipps hierzu dankbar.)
Private Nachricht senden Benutzer-Profile anzeigen
 
niniwe
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 23
Anmeldedatum: 03.07.12
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 16.08.2012, 09:58     Titel:
  Antworten mit Zitat      
Weil die Fragestellung anscheinend nicht gut formuliert war.
Ich versuche ein Struckturiertes Exeldokument mit Überschriften und einer Art Achsenbeschriftungen zu erstellen.
Private Nachricht senden Benutzer-Profile anzeigen
 
draussen
Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 90
Anmeldedatum: 26.11.10
Wohnort: DE
Version: 2010b,2020a
     Beitrag Verfasst am: 16.08.2012, 11:06     Titel:
  Antworten mit Zitat      
Hallo,

generell kann der xlswrite Befehl laut help so angewendet werden:

Code:

xlswrite(filename,A)
xlswrite(filename,A,sheet)
xlswrite(filename,A,range)
xlswrite(filename,A,sheet,range)
 


In Deinem Fall gibt es zwei Möglichkeiten

1. Du Verwendest den Befehl zweimal, einmal für die Matritzen und einmal für die Überschriften da beide unterschiedliche Formate haben. (Quasi umgekehrt wie bei xlsread).

Code:

xlswrite('test.xls',Matrix_A,'tabelle1','A2)
xlswrite('test.xls',Überschriftenarray,'tabelle1','A1)
 


2. Du basteltst Dir in Matlab ein cell-array zusammen, das quasi so aussieht wie es in Excel sein soll. Also mit Text und Matrizen, aber die Matrizenkomponenten auch alss Cells und schiebts das cell-array auf einmal nach excel.

Code:

%Matrix erstellen
A=[1 2 3; 4 5 6];
%Matrix in cellarray umwandeln
B=mat2cell(A,ones(1,size(A,1)),ones(1,size(A,2)));
%Überschriften erstellen
text={'test1','test2','test3'};
%Exportarray zusammenbauen
C=[text;B];
%Export nach Excel
xlswrite('test.xls',C,'tabelle1','B10')
 


MfG

Georg
_________________

Der Einäugige ist unter den Blinden der König!!!
Private Nachricht senden Benutzer-Profile anzeigen
 
niniwe
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 23
Anmeldedatum: 03.07.12
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 20.09.2012, 18:09     Titel:
  Antworten mit Zitat      
Vielen Dank! Variante 2 klappt prima!
(Variante 1 hatte ich nämlich schon und es nervt mich total mein Programm nur wegen xlswrite so lahm zu legen Wink )
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.