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

Aus Excel abgerufene Vektoren erscheinen nicht im Workspace

 

Eimily
Forum-Anfänger

Forum-Anfänger


Beiträge: 15
Anmeldedatum: 09.09.15
Wohnort: Augsburg
Version: ---
     Beitrag Verfasst am: 16.09.2015, 15:26     Titel: Aus Excel abgerufene Vektoren erscheinen nicht im Workspace
  Antworten mit Zitat      
Hallo ihr Lieben!

Ich möchte mit wettergraph_f.m zwei Excel Spalten (Temperatur und Globalstrahlung) in Matlab einlesen und sie anschließend über die Zeit plotten. Das mit dem Plot klappt so weit, nur werden mir die zugehörigen Vektoren T und Gh nicht in den Workspace geladen. Weiß jemand woran das liegt?

Liebe Grüße
Anna

wettergraph_f.PNG
 Beschreibung:

Download
 Dateiname:  wettergraph_f.PNG
 Dateigröße:  39.18 KB
 Heruntergeladen:  439 mal
wettergraph_f.m
 Beschreibung:

Download
 Dateiname:  wettergraph_f.m
 Dateigröße:  1.11 KB
 Heruntergeladen:  452 mal

_________________

Masterarbeit - auf in den Kampf!
Private Nachricht senden Benutzer-Profile anzeigen


Epfi
Forum-Meister

Forum-Meister



Beiträge: 1.134
Anmeldedatum: 08.01.09
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 16.09.2015, 15:40     Titel:
  Antworten mit Zitat      
Die angehängte Datei ist eine Funktion. In Matlab hat eine Funktion einen eigenen Workspace. Variablen, die dort angelegt werden, werden bei Beendigung der Funktion wieder gelöscht.

Wenn Du willst, dass die Funktion die Werte an das aufrufende Skript zurück gibt, musst Du diese Werte als Rückgabewerte definieren:

Code:

function [ ausgabe_eins, ausgabe_zwei ] = testfunktion(eingabe_eins, eingabe_zwei)
   ausgabe_eins = ones(1, 10);
   ausgabe_eins = eingabe_eins * ausgabe_eins;

   ausgabe_zwei = eingabe_zwei * 5;
end
 

Zurück gegeben wird dann jeweils der letzte Wert, den eine Variable am Ende der Funktion hat.
Private Nachricht senden Benutzer-Profile anzeigen
 
Eimily
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 15
Anmeldedatum: 09.09.15
Wohnort: Augsburg
Version: ---
     Beitrag Verfasst am: 17.09.2015, 11:11     Titel: Vereinfachte verbesserte Funktion gibt nur ans zurück
  Antworten mit Zitat      
Danke für den Tipp! Ich hab die Rückgabe in der function wie du gesagt hast definiert und das ganze m-file stark vereinfacht um einen Überblick zu bekommen. Leider bekomme ich jetzt, obwohl ich zwei Vektoren datT und datGh in den Workspace laden will, immernoch nur ein "ans" als Rückgabe. --> Siehe Screenshot!
Woran könnte das liegen? Ist irgend ein grundlegender Fehler in der Funktion?

Liebe Grüße
Anna

wettertest.PNG
 Beschreibung:

Download
 Dateiname:  wettertest.PNG
 Dateigröße:  27.29 KB
 Heruntergeladen:  426 mal

_________________

Masterarbeit - auf in den Kampf!
Private Nachricht senden Benutzer-Profile anzeigen
 
Winkow
Moderator

Moderator



Beiträge: 3.842
Anmeldedatum: 04.11.11
Wohnort: Dresden
Version: R2014a 2015a
     Beitrag Verfasst am: 17.09.2015, 11:32     Titel:
  Antworten mit Zitat      
poste bitte lieber code als einen screenshot.
du rufst wettertest ohne rückgabe argumente auf. darum das ans.
_________________

richtig Fragen
Private Nachricht senden Benutzer-Profile anzeigen
 
Eimily
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 15
Anmeldedatum: 09.09.15
Wohnort: Augsburg
Version: ---
     Beitrag Verfasst am: 17.09.2015, 12:46     Titel: Lösung gefunden
  Antworten mit Zitat      
Danke!!! Hab's geschafft meine zwei Vektoren mit folgender function in den Workspace zu laden:

Code:
function wettertest
[Excel_Datei]= uigetfile('*.xlsx','Bitte Datei auswählen');
Wet_Dat = xlsread(fullfile(Excel_Datei));
answer1=ones(1,97);                
datT=Wet_Dat(:,3);                  
answer1=datT;
assignin('base','datT', answer1);  
answer2=ones(1,97);                
datGh=Wet_Dat(:,4);                
answer2=datGh;
assignin('base','datGh', answer2);  
plot(datT,datGh)


Es funktioniert, aber geht es auch eleganter/kürzer?
_________________

Masterarbeit - auf in den Kampf!
Private Nachricht senden Benutzer-Profile anzeigen
 
Epfi
Forum-Meister

Forum-Meister



Beiträge: 1.134
Anmeldedatum: 08.01.09
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 17.09.2015, 12:50     Titel:
  Antworten mit Zitat      
assignin sollte man nicht verwenden. Außer man steht auf stundenlange Fehlersuche und Kollegen, die einem die Pest an den Hals wünschen...

Mit der Funktion aus dem Screenshot warst Du schon auf dem richtigen Weg. Du musst sie nur noch richtig aufrufen:
Code:

[wert1, wert2] = wettertest;
 


Dann liegen die Rückgabewerte der Funktion wettertest in den beiden Variablen wert1 und wert2 .
Private Nachricht senden Benutzer-Profile anzeigen
 
Eimily
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 15
Anmeldedatum: 09.09.15
Wohnort: Augsburg
Version: ---
     Beitrag Verfasst am: 17.09.2015, 13:30     Titel:
  Antworten mit Zitat      
Ahhh... Vielen Dank!!! Very Happy Laughing
_________________

Masterarbeit - auf in den Kampf!
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.