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

Excel mit Matlab bearbeiten

 

snowtim
Forum-Anfänger

Forum-Anfänger


Beiträge: 49
Anmeldedatum: 31.03.08
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 19.05.2010, 18:14     Titel: Excel mit Matlab bearbeiten
  Antworten mit Zitat      
Hallo zusammen,
brauch mal einwenig hilfe...
Ich will über Matlab Daten in eine Excel datei schreiben.
Code:

excel = actxserver('Excel.Application');
excel.Workbooks.Open('D:\LiDAR\Daten\Matlab\unusual_data.xls');


xlswrite('unusual_data', {num2str('Time')},'Ws','A2');
xlswrite('unusual_data', {num2str('Measurement system')},'Ws','B2');
xlswrite('unusual_data', {num2str('Wiper Count')},'Ws','C2');
xlswrite('unusual_data', {num2str('Tm')},'Ws','D2');
xlswrite('unusual_data', {num2str('Hight')},'Ws','E2');
xlswrite('unusual_data', {num2str('Wind speed')},'Ws','F2');
xlswrite('unusual_data', {num2str('Availability')},'Ws','G2');
xlswrite('unusual_data', {num2str('Azimuth direction angle')},'Ws','H2');
%....... und soweiter

Jetzt wenn ich meinen m.file ausführe bekomme ich bei jedem jedem einzelnen xlswrite ein Fenster angezeigt von Excel :
Eine Datei mit dem Namen 'unusal_data.xls' existiert schon an diesem Platz.Soll sie ersetzt werden? [ja nein abbrechen]

Wie bekommen ich es denn hin das einfach in die entsprechende Datei jeweils nur meine xlswrite eingefügt wird?
eine weitere Fage wäre noch wie bekomme ich es hin das zuvor das ganze Ecxel sheet erstmal wieder komplet leer ist?

mir ist auch gerade aufgefallen wenn ich jetzt die Excel-datei löschen will. geht dies leider auch nicht. Ich bekomme mitgeteilt, dass die Datei von Excel noch genutz wird obwohl ich kein excel offen habe.
Und wenn ich einen neuen name einsetzte für die Excel Datei
Code:
xlswrite('neu', {num2str('Time')},'Ws','A2');

dann läuft es auch einmal aber beim zweiten ausführen bekomme ich wieder die meldung wie oben

schon mal danke und gruß

Tim[/code]
Private Nachricht senden Benutzer-Profile anzeigen


Vito
Forum-Guru

Forum-Guru


Beiträge: 315
Anmeldedatum: 02.11.09
Wohnort: Stuttgart
Version: ---
     Beitrag Verfasst am: 19.05.2010, 21:24     Titel:
  Antworten mit Zitat      
Hi,

warum machst du das nicht so:
Code:

excel = actxserver('Excel.Application');
excel.Workbooks.Open('D:\LiDAR\Daten\Matlab\');

mydata = {'Time', 'Measurement system', ...};% so hast du es uebersichtlicher und das xlswrite wird nur einmal durchgeführt.
xlswrite('unusual_data.xls', mydata,'Ws','A2'); % das Measurement system wird in B2 eingeschrieben etc.
 

Wenn du dein File ausführst muss Excel immer geschlossen sein.

Gruß,
Vito
Private Nachricht senden Benutzer-Profile anzeigen
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.501
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 19.05.2010, 21:30     Titel:
  Antworten mit Zitat      
Hallo,

die Frage ist doch vielmehr: warum erst mit ActiveX arbeiten, wenn man dann doch mit xlswrite arbeitet? Also: entweder die ActiveX-Geschichte weglassen, oder auch die xlswrite-Befehle durch Befehle ersetzen, die über ActiveX mit dem Worksheet interagieren.

Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen
 
snowtim
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 49
Anmeldedatum: 31.03.08
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 19.05.2010, 22:15     Titel:
  Antworten mit Zitat      
Danke erstmal für eure schnellen Antworten.
Die Idee von Vito hatte ich auch schon aber dann kommen bei mir auch noch Schleifen und etc.
Da klingt die Anwort Harald besser. Nur leider wie sehen den ActiveX-Befehle für Excel aus?
Hatte bis jetzt nur mit xlswrite gearbeitet. Wie sähe den der Code für diese Zeile aus?
Code:
xlswrite('unusual_data', {num2str('Tm')},'Ws','D2');


Gruß Tim
Private Nachricht senden Benutzer-Profile anzeigen
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.501
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 19.05.2010, 22:47     Titel:
  Antworten mit Zitat      
Hallo,

schau dir dazu vielleicht die Doku an:

http://www.mathworks.com/access/hel.....rnal/bqdwu3j.html#bqd_o32

Numerische Daten müssen übrigens nicht umgewandelt werden, bevor sie nach Excel geschrieben werden.

Grüße,
Harald[/url]
Private Nachricht senden Benutzer-Profile anzeigen
 
snowtim
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 49
Anmeldedatum: 31.03.08
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 20.05.2010, 13:21     Titel:
  Antworten mit Zitat      
erst nochmal danke für die Antwort doch leider bin ich zu keinem wirklichen Ergebniss gekommen. für mich ist das alles neu mit activeX.
und wenn ich mir die Beispiele von dem Link an schaue bekomme ich immer nur Fehlermeldungen.
könnte mir da jemand nochmal weiter helfen und einfach mal einen kruzen m.file schreiben der über activeX einfach in die Zelle A1 von Excel etwas einträgt, wenn es nicht zuviel verlangt ist würde ich mich sehr darüber freuen. Dann kann ich auch weiter ausprobieren, wenn das grundgerüst schon mal stimmt.

Danke

Gruß Tim
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.