Új hozzászólás Aktív témák
-
kovisoft
őstag
Ha jól értem, amit szeretnél csinálni, akkor azt meg tudod valósítani egy DictCursor-ral, aminek a kulcsai éppen az oszlopnevek. Nézd meg ezt a módszert, ez szerintem "SELECT *"-gal is megy, használhatod közvetlenül az oszlopneveket a result set-ben:
for row in results:
darab = row[holvan] -
kovisoft
őstag
Az a magyarázat, hogy parametrized query-ben csak az adat jellegű dolgokat parametrizálhatod, azok jöhetnek dinamikusan egy paraméterből (amit a , utáni listában adsz meg). Táblanév, oszlopnév, SQL kulcsszó nem jöhet paraméterből, legalábbis ha jól tudom.
Ha oszlopnevet akarsz dinamikusan beletenni a query-be, arra nem tudok más megoldást, mint hogy magát a teljes SQL query stringet összeépíted (ezt csinálja a %-os módszer). Ez persze nem ugyanaz, mint amit szeretnél, de azt szerintem nem is lehet megcsinálni úgy, ahogy szeretnéd. Vagy ha tévedek, akkor majd kijavít valaki.
-
samujózsi
senior tag
Ez copy-paste? Mert a holvan=helyseg akkor... nem túl nyerő.
Bocs, most mennem kell, ha nem ez a gond, akkor majd este, feltéve, hogy fel tudom éleszteni a mysql szerverem.Egyébként ez melyik python?
Mert én csak 3-ast használok, ahhoz meg nem találtam MySQLdb modult, csak pyMySQL-t. -
kovisoft
őstag
Két datetime különbsége timedelta típusú. Ezt nem tudod szimplán összehasonlítani egy int-tel. Helyette a timedelta-ból kell egy int-et csinálnod. Pl. ha az adott maximum másodpercet jelent, akkor a timedelta seconds attribútumával kell összehasonlítani. Ha a maximum stringben van, akkor először azt is konvertáld int típusra, valahogy így:
diftime = most - ido()
maximum = "10"
print int(maximum) - diftime.seconds -
KEAN
tag
try ... except szerkezetben bármilyen hiba történik, akkor aktiválódni fog az except ág, szóval a kérdésedre a válasz igen.
Amúgy lehet "szűrni" a hibákra, ha különféle módokon akarod lekezelni őket. (Persze neked most mindkét parancs IOError-t dobna, szóval ezzel itt és most nem sokra mész...)try:
some_risky_thing
except KeyError:
do_something_with_keyerror
except IndexError:
do_something_with_indexerror(A fenti példában csak a két "nevesített" hibát kapjuk el, minden más hiba a program leálláshoz vezet vagy legalábbis traceback fog keletkezni.)
-
justmemory
senior tag
Szia,
én úgy tudom, hogy ha a try-ban akármelyik feltétel nem teljesül, akkor már az except-re fog futni a dolog, magyarul ha a file1 nem nyitható, akkor error-t fog dobni.
Én egyébként lehet inkább így írnám (noha én is csak hobbista vagyok
):def olvasni():
try:
with open("testfile.txt”,”r”) as testfile, with open(“testfile1.txt”,”r”) as testfile1:
tartalom = testfile.readlines()
tartalom1 = testfile1.readlines()
amit_csinálni_akarsz()
akármi = "1"
except:
akármi = "0"
return akármiÍgy ha akármelyik fájlt nem tudja megnyitni, akkor az except-re fog futni.
A fenti módszer csak python 2.7 vagy afölötti verzióval működik, 2.6 és az alatt úgy kell, hogy:
try:
with open("testfile.txt”,”r”) as testfile:
with open("testfile1.txt”,”r”) as testfile1: -
axioma
veterán
Varj, a valtozonak az erteket akarod futtatasi parameterbol feltolteni, nem? A valtozot letrehozod valamilyen neven, nem azt adod kivulrol a programnak...
Keresni is igy kene, nem a valtozo tulajdonsaga ez, hanem a parameterek atvetelenek szintaktikaja kell szerintem neked.
Szerk. sys.argv, de ez mint mashol is tartalmazza a futtatott script neve't. Igy az elso argumentum [nem param a jo terminologia, bocs] az a sys.argv[1]
sonar: kosz, mobilrol lassu voltam...
Új hozzászólás Aktív témák
- Ilyen olcsó sem volt még egy Apple notebook
- Luck Dragon: Asszociációs játék. :)
- Mibe tegyem a megtakarításaimat?
- Borderlands 4
- Formula-1
- Okosóra és okoskiegészítő topik
- PlayStation 5
- Itt a Galaxy S26 széria: az Ultra fejlődött, a másik kettő alig
- GL.iNet Flint 2 (GL-MT6000) router
- Lightyear - befektetési app
- További aktív témák...
- Laptop ramok DDR4 8Gb (10e/db) 16GB (20e/db) 32GB ( 44e/db) modulok 3200Mhz párban is! - garival
- HP ZBook Fury 17 G8 i7-11800H 32 GB RAM 1TB SSD NVIDIA RTX A3000 Garancia
- Hitachi 2TB HDD 7200rpm (HDS722020ALA330)
- Corsair VENGEANCE LPX 2x16GB DDR4 3200MHz CL16 - Új, bontatlan - Eladó!
- Makulátlan Samsung S24 Ultra 512Gb !!! Garanciával + sok kiegészítővel !!!
Állásajánlatok
Cég: Laptopműhely Bt.
Város: Budapest


