Seite 2 von 2

Verfasst: Montag 20. April 2009, 19:46
von Jan.O
gerold hat geschrieben:Hallo!

Ich möchte allgemein darauf hinweisen, dass dieser Thread noch aus dem Jahr 2006 stammt. Und sich inzwischen alle Beteiligten viel besser mit Python auskennen, als das vor zwei Jahren der Fall war.

mfg
Gerold
:-)
Hi Gerold,

Wolltest du damit vor 1,25 Jahren sagen, dass diese Methode Variablen zu globalisieren nach der Python-Philosophie nicht verwerflich ist?

Ich habe nämlich gerade genau das selbe problem, welches in diesem Thread beschrieben wurde, mit einem Web Framework. Ich muss die threadgebundene DB-Verbindung in allen Klassen verwenden können, die teilweise auch in Module ausgelagert sind.

Verfasst: Montag 20. April 2009, 20:07
von DasIch
Das hat nichts mit Python zu tun. Dieses Design ist ein Alptraum. Eines der wichtigsten Dinge um sauberen Code zu erzeugen ist Seiteneffekte zu vermeiden und nicht noch zu forcieren.

Verfasst: Montag 20. April 2009, 21:08
von gerold
Jan.O hat geschrieben:Wolltest du damit vor 1,25 Jahren sagen, dass diese Methode Variablen zu globalisieren nach der Python-Philosophie nicht verwerflich ist?
Hallo Jan.O!

Ich weiß nicht, was du mich damit fragen möchtest. Aber das was ich damals sagen wollte ist, dass es bessere Möglichkeiten gibt, eine Variable "global" für alle in das Programm eingebundenen Module zu halten.

Da ich mich mit SQLAlchemy nicht auskenne, kann ich dir bei deinem Problem nicht helfen. Aber wenn du eine Variable global für alle Programmmodule halten willst, dann musst du diese Variable nur in ein Modul schreiben und dieses Modul in jedem anderen Modul importieren, in welchem du diese Variable brauchst.

globalvars.py:

Code: Alles auswählen

#!/usr/bin/env python
#coding: utf-8
# globalvars.py

global_value_a = 10
global_value_b = 20
module1.py:

Code: Alles auswählen

#!/usr/bin/env python
#coding: utf-8
# module1.py

import globalvars


def print_globalvars():
    print globalvars.global_value_a
    print globalvars.global_value_b
    globalvars.global_value_a = 11
    globalvars.global_value_b = 21
module2.py:

Code: Alles auswählen

#!/usr/bin/env python
#coding: utf-8
# module2.py

import globalvars


def print_globalvars():
    print globalvars.global_value_a
    print globalvars.global_value_b
    globalvars.global_value_a = 12
    globalvars.global_value_b = 22
myprogram.py:

Code: Alles auswählen

#!/usr/bin/env python
#coding: utf-8
# my_program.py

import globalvars
import module1
import module2


def main():
    module1.print_globalvars()
    module2.print_globalvars()

    print globalvars.global_value_a
    print globalvars.global_value_b


if __name__ == "__main__":
    main()
Das löst aber nicht dein Threading-Problem. Außerdem ist es ratsamer, alle benötigten Objekte beim Aufruf einer Funktion an diese zu übergeben -- und nicht irgendwoher von einem globalen Variablen-Modul zu holen.

Wenn ich von mehreren Threads aus Zugriff auf eine Datenbank brauche, dann bekommt jeder Thread eine eigene Connection. Fertig Aus! Und die Sache ist gegessen. Wie das bei SQLAlchemy läuft, weiß ich nicht.

mfg
Gerold
:-)

Re: Modulübergreifende Globale Variablen und Klassenvariablen

Verfasst: Dienstag 13. Februar 2024, 15:01
von Ghostfighter6
Moin,
aber der sinnvollste Beitrag war von Tristan aus 2008 ;)
Und der hat mir sehr gut geholfen ... die Kommentare, dass globale Variablen nicht verwendet werden sollen ist zwar nett, aber nicht hilfreich :D

Re: Modulübergreifende Globale Variablen und Klassenvariablen

Verfasst: Dienstag 13. Februar 2024, 15:15
von Dennis89
Naja, warte mal bis du ein etwas aufwendigeres Programm schreiben musst, dann siehst du, dass das sehr hilfreich ist.

Re: Modulübergreifende Globale Variablen und Klassenvariablen

Verfasst: Dienstag 13. Februar 2024, 15:16
von __blackjack__
@Ghostfighter6: Doch das ist hilfreich Fehler zu vermeiden und unverständliche und damit unwartbare Programme zu schreiben.

Re: Modulübergreifende Globale Variablen und Klassenvariablen

Verfasst: Dienstag 13. Februar 2024, 15:38
von Ghostfighter6
@Dennis89 :
Keine Ahnung, ob ca. 10k Zeilen mit Zugriffen auf 2Server, Testcase-Erstellung, automatisches Nachflashen vom Steuergerät, automatisches Testen und Auswerten des Testreports und Upload der Testergebnisse auf den Server aufwendig ist.
Ich muss teilweise bis 20 Parameter in die Funktionen übergeben, da ich das nicht im OOP machen will - bin da halt ned so fit.
Und eine Firma gibt dir ned die nötige Zeit, um erstmal in Ruhe 6 oder mehr Monate mit dem Selbststudium zu verbringen und die saubere Programmierung zu erlernen.
Die beauftragen einen Scrum-Master der dich jeden Tag triezt und fragt wie lange du gearbeitet hast, was du gemacht hast, wie lange du noch brauchst und ob 13 Storypoints für die Aufgabe nicht zu viel sind.
Die wollen übermorgen eine fertige Lösung haben ... die natürlich 100% Testcoverage hat.
Vor Jahrzehnten konnte man sich mal in Ruhe einarbeiten und hat sogar noch Kurse dafür bekommen ... alles schon lange gestrichen ... darum arbeiten bei uns nur noch preiswerte Inder :D

Re: Modulübergreifende Globale Variablen und Klassenvariablen

Verfasst: Dienstag 13. Februar 2024, 15:49
von __blackjack__
@Ghostfighter6: Also ist das kein Problem das man mit globalen Variablen löst sondern eines wo man Einzelwerte sinnvoll zu Objekten zusammenfassen sollte. Was an sich erst mal nicht einmal OOP ist, denn auch in prozeduraler oder funktionaler Programmierung hat man Verbunddatentypen. Also da wo man in C `struct` oder in Pascal RECORD oder in strukturierten BASIC-Dialekten TYPE verwenden würde. Dafür eine Klasse zu verwenden ist ja noch nicht OOP, aber in Python der Weg so etwas zu handhaben.

Re: Modulübergreifende Globale Variablen und Klassenvariablen

Verfasst: Dienstag 13. Februar 2024, 16:13
von Kebap
Huch, wieso flammt denn hier plötzlich ein 15 Jahre alter Thread auf?

Re: Modulübergreifende Globale Variablen und Klassenvariablen

Verfasst: Dienstag 13. Februar 2024, 17:33
von __blackjack__
@Kebap: Wieso nicht? Globale Variablen sind zeitlos und im Grunde ja sogar programmiersprachenübergreifend. 🙂