Diskuze: Importovanie premennej v cykle
Člen
Zobrazeno 10 zpráv z 10.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V prvom rade, aj keď integery sú (ako všetko) v Pythone objekty, stále sú immutable, takže ak pochádzaš z iného jazyka tak to je podobné, ako keby si ich všade presúval by value. Pokiaľ chceš aby a a b zdieľali nejaké immutable dáta, musíš im ich posunúť v nejakom mutable kontajneri (v tvojom prípade by si mohol vyskúšať presúvať zoznam [counter]).
Ešte by som ale pre úplnosť rád vedel, akým spôsobom tie dva skripty spúšťaš súbežne, if I may ask.
Ty v podstate potrebuješ to čo sa v iných jazykoch volá
pointer/referencia.
Myslím si, že je veľmi pravdepodobné, že niečo navrhuješ zle, keď to
potrebuješ riešiť takto, prečo nemôžeš použiť v b.py rovno
a.counter namiesto poc.
Inak tiež by ma zaujímalo ako to spúštaš súbežne, lebo asi ti to nebude fungovať tak ako by si chcel , ale ako tak pozerám budeš asi musieť použiť multithreading.
Toto hore je len príklad. V programe presúvam celé pole, ktoré sa v a.py mení a v b.py potrebujem pracovať s novými dátami.
Jediný dôvod je, že premenná poc je kratšia ako a.counter (lenivosť)
Konkrétne teraz to riešim takto
if __name__ == "__main__":
while(1):
pole+=1
fh = open("hello.txt", "w")
fh.write(str(pole))
fh.close()
a následne v b.py
fh = open("hello.txt", "r")
pole = fh.read()
Neviem prečo ale cítim, že to nieje najlepšie riešenie
Ahoj, to první nefunguje proto, že import si spustí kód z a.py, nepřipojuje se to na stávájící program.
Navíc to
if __name__ == "__main__":
se provádí pouze, pokud jsi spustil Python program/skript přes ten soubor, jinak je v tom
__name__
uložená jiná hodnota, která indikuje, že ten soubor voláš přes import.
Můžeš zkusit ještě použít sockety lokálně, nebo použít multiprocessing a dopočítávat ta data na pozadí. Ale můžu radit blbost, když nevím, co takto chceš přesně řešit.
Našiel som niečo takéto (veľmi sa to nelíši od pôvodného riešenia ale je to jednoduchšie).
a.py
import pickle
import sys
if __name__ == "__main__":
list = 'bla'
pickle.dump(list, open( "save.p", "wb" ))
b.py
import pickle
import os
list = pickle.load( open( "save.p", "rb" ) )
print(list)
os.remove(r"save.p")
Neexistuje niečo kde by program ukladal dáta niekde mimo (nevytváral by reálnu zložku ako save.p alebo hello.txt) ale fungovalo by to rovnako ako riešenia predtým?
Jak jsem psal výše, sockety nebo multiprocessing, ale záleží, co přesně děláš. Posílat si pole mezi programy je samo o sobě dost divné.
Zobrazeno 10 zpráv z 10.