Autor
|
Thema: Fehler mit obj.exp.expstat(...); (532 mal gelesen)
|
pom Mitglied Dipl.-Ing. (FH)
Beiträge: 182 Registriert: 25.08.2006
|
erstellt am: 01. Dez. 2006 16:11 <-- editieren / zitieren --> Unities abgeben:
Hi Forum, ich hab es in einem anderen Thread bereits angekündigt, ich hab ein neues Problem. Diese Problem bringt meine Simulation zum Absturz. Der Fehler passiert in Zeile 14 in dieser steht: "obj.exp.expstat(StatistikMA);". Zum drum herum: Dies ist eine Methode mit der ich die Statistik aller Mitarbeiter und Stationen in meinem Model auslese und an externe Excellisten schicke. Die Methode erzeugt nicht immer einen Fehler, was die Fehler findung etwas erschwert. Anbei die Fehlermeldung. Meine Vermutung: Ich habe 79 Mitarbeiter welchem jeweils ein oder mehrer bestimmte Dienste zugewiesen sind. Der Fehler passiert also dann wenn einer dieser Mitarbeiter an einer Stelle ist wo die Statistik nicht ausgelesen werden kann. Wisst ihr ob eine Mitarbeiter in eine Situation kommen kann wo eM-Plant kein zugriff auf seine Statistik hat oder habt ihr eine andere Idee weshalb dieser Fehler kommt? Jeder hinweis wird mir helfen also meldet euch Hier mein Quellcode: Code: is i:integer; y:String; obj bject; StatistikMA, StatistikStationen:Table;do StatistikMA.create; StatistikStationen.create; If Ereignisverwalter.holeNaechsteEreignisZeit /= 0 then for i:=1 to MA_Tabelle.ydim loop y:=".kst7177.MA.MA" + sprint(i) + ":1"; obj:=str_to_obj(sprint(y)); obj.exp.expstat(StatistikMA); If MA_Tabelle[6,i] = Void then StatistikMA.loeschen(`[*,i]) end; next; StatistikMA.schreibeExcelDatei(ExterneDatei); for i:=2 to Stationen_Tabelle_4CR.ydim loop Stationen_Tabelle_4CR[1,i].Statistik(StatistikStationen); next; StatistikStationen.schreibeExcelDatei(ExterneDatei); Print "Statistiken an die Excel Dateien übertragen!"; else Print "KEINE STATISTIK ERFASST SIMULATION STARTEN!!"; end; end;
MFG Patrick Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
Ex-Mitglied
|
erstellt am: 01. Dez. 2006 23:17 <-- editieren / zitieren -->
setz mal das "statistikma.create" direkt vor "obj.exp.expstat(StatistikMA);" und schreib die jeweilige Zeile in eine andere Tabelle lass dir mal das "obj" mit print ausgeben- sieht ziemlich "wild" aus. was willst Du mit StatistikMA.loeschen(`[*,i]) loeschen ? versuchs mal mit StatistikMA.loeschen(`[1,i]..`[*,i]); oder StatistikMA.entfernezeile(i); Gruss ------------------ Der Simulator |
pom Mitglied Dipl.-Ing. (FH)
Beiträge: 182 Registriert: 25.08.2006
|
erstellt am: 04. Dez. 2006 11:08 <-- editieren / zitieren --> Unities abgeben:
StatistikMA.loeschen(`[*,i]) loeschen soll bewirken das wenn ein Mitarbeiter ausgelesen wird der keinen Dienst hat, aber dennoch in der Tabelle drin steht, dessen Zeile bzw. Statistik gelöscht wird. StatistikMA.entfernezeile(i); ist da natürlich die bessere Lösung stimmt, danke. Komischer Weise konnte ich die Methode einmal ohne Probleme ausführen. Consolen Auszug. Mit Print obj; Was mich hier wundert is die erste Zeile ".Kst7177.MA.MA16" wo kommt der her? Weil später wird ".Kst7177.MA.MA16:1" ausgelesen. .Kst7177.MA.MA16 .Kst7177.MA.MA2:1 .Kst7177.MA.MA3:1 .Kst7177.MA.MA4:1 . . .Kst7177.MA.MA16:1 . . .Kst7177.MA.MA78:1 .Kst7177.MA.MA79:1 Statistiken an die Excel Dateien übertragen! Und beim zweiten mal ausführen: Neue Fehlermeldung siehe Bilder. Das hat er beim neuladen der automatisch gespeicherten Datei in der Console ausgegeben: VOID Fehler in Methode '.Kst7177.Sim.Statistik_Übertragen' in Zeile 16: Ein 'VOID' kann keine Methode 'exp' empfangen. Hoffe das Aufgrund der neuen Fehlermeldung jemand eine Idee hat! MFG Patrick Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
pom Mitglied Dipl.-Ing. (FH)
Beiträge: 182 Registriert: 25.08.2006
|
erstellt am: 04. Dez. 2006 11:30 <-- editieren / zitieren --> Unities abgeben:
|
pom Mitglied Dipl.-Ing. (FH)
Beiträge: 182 Registriert: 25.08.2006
|
erstellt am: 04. Dez. 2006 12:33 <-- editieren / zitieren --> Unities abgeben:
Ok ich glaub ich hab es hinbekommen. Jedenfalls läuft das ganze wieder ohne Fehler. Ich hab den Werker MA1 gelöscht genau wie den MA16. Beide neu eingefügt und die Methode etwas umgeschrieben. StatistikMA.create; for i:=1 to MA_Tabelle.ydim loop obj:=str_to_obj(sprint(MA_Tabelle[1,i])+sprint(":1")); obj.exp.expstat(StatistikMA); If MA_Tabelle[6,i] = Void then StatistikMA.entferneZeile(i); end; next; StatistikMA.schreibeExcelDatei(ExterneDatei); Jetzt läuft wieder alles... und wieder mal hab ich keine Ahnung wie dieses Phänomen zustande gekommen ist. y:=sprint(MA_Tabelle[1,i])+sprint(":1"); Print y; .Kst7177.MA.MA1:1 obj:=str_to_obj(y); Print obj; .Kst7177.MA.MA16 aber jetzt gehts wieder nach dem ich die "verbugten" Mitarbeiter ausgewechselt hab. MFG Patrick Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
Homer Simpson Mitglied
Beiträge: 345 Registriert: 14.09.2005
|
erstellt am: 05. Dez. 2006 08:57 <-- editieren / zitieren --> Unities abgeben: Nur für pom
Das "print"-Phänomen ist schon merkwürdig. Ich kann das Problem bei mir nicht nachvollziehen. Ohne das Modell kann ich nicht sagen, was da passiert. Übrigens: sprint funktioniert ähnlich wir print, d.h. es kann mehrere durch Komma getrennte Argumente hintereinanderschreiben. Man kann also schreiben: y := sprint(MA_Tabelle[1,i], ":1"); . Da es sich in diesem Beispiel um Strings handelt, kann man sie statt dessen auch einfach nur addieren: y := MA_Tabelle[1,i] + ":1"; Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
pom Mitglied Dipl.-Ing. (FH)
Beiträge: 182 Registriert: 25.08.2006
|
erstellt am: 05. Dez. 2006 10:12 <-- editieren / zitieren --> Unities abgeben:
Hi, MA_Tabelle[1,i] ist bei mir als Object formatiert, da ich die Tabelle noch in anderen Methoden verwende (erspart mit ne Menge Tip Abreit). Hast recht, man kann es auch anders schreiben. Aber ich hatte ja das Problem das aus MA1:1 -> MA16 wurde, warum auch immer, und deswegen hatte ich mehrere Varianten ausprobiert. Kann es sein das eM-Plant aufgrund von einer Vererbung MA1:1 mit MA16 verwechselt hat? Weil als ich MA1 gelöscht hatte wurde auch MA16 automatisch gelöscht. Ich glaub mittlerweile das mein eM-Plan irgend wie ein Schuss hat... Erst das Problem mit DateTime und jetzt das mit den Werkern. Jedenfalls sind die Werker wieder alle Glücklich und machen das was sie sollen ohne Fehler zu Produzieren MFG Patrick PS: Das Modell kann ich leider nicht verteilen Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
Ex-Mitglied
|
erstellt am: 05. Dez. 2006 12:43 <-- editieren / zitieren -->
es bringt keinem in diesem Forum etwas, wenn ueber vermeintliche Fehler geschrieben wird und es nur schwer oder unmöglich ist, diese nachzuvollziehen. In fast allen Fällen muss in diesem Forum aus dem Geschriebenen ein Modell nachgebaut werden. Es wäre deshalb sicherlich effektiver, entweder ein Modellausschnitt oder das Modell selbst zu schicken- wenn nicht mit einer Studentenlizenz erstellt- oder zumindestens so viel Informationen mit- zugeben, sodass man das beschriebene Phänomen nachbilden kann. Nun stehen 2 Fragen im Raum, auf die es ganz sicherlich eine Erklärung gibt, die allen im Forum dienen würde, aber wir können die beschriebenen Phänomene mit den gegebenen Informationen nicht reproduzieren ! Deshalb der Appell an alle, denkt bitte bei der Formulierung daran, dass der Lesende eine Möglichkeit hat, die Fragestellung auch nachzubilden. Gruss ------------------ Der Simulator
|
pom Mitglied Dipl.-Ing. (FH)
Beiträge: 182 Registriert: 25.08.2006
|
erstellt am: 07. Dez. 2006 10:13 <-- editieren / zitieren --> Unities abgeben:
Hi, ich hab versucht das Modell soweit ab zu specken das ich es euch ins Forum stellen kann. Aber wenn ich es soweit habe und es auf den Fehler teste ist er weg... Ich werde mich am Freitag weiter daran versuchen. Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |