Portál AbcLinuxu, 19. dubna 2024 01:28
Řešení dotazu:
#!/usr/bin/python import csv, sqlite3 con = sqlite3.connect(":memory:") cur = con.cursor() cur.execute("CREATE TABLE t (ID_zak,za_jmeno,za_ulice,za_mesto,za_telefon,za_mail,za_ucet);") with open('zak.csv', 'r') as fin: dr = csv.reader(fin) for row in dr: to_db = [unicode(row[0],"utf8"), unicode(row[1],"utf8"), unicode(row[2],"utf8"), unicode(row[3],"utf8"), unicode(row[4],"utf8"), unicode(row[5],"utf8"), unicode(row[6],"utf8")] con.execute("INSERT INTO t (ID_zak,za_jmeno,za_ulice,za_mesto,za_telefon,za_mail,za_ucet) VALUES (?,?,?,?,?,?,?);", to_db) con.commit() con.close()
":memory:"
jsem nikdy nepoužil, pže jsem si data chtěl prohlédnout v DB Browser for SQLite, zda to vypadá dle potřeby a otestovat tam i SQL dotazy. S db začínám, takže mi takovéto "udělátko" pěkně slouží k odladění dotazů. Poradíte mi ještě jak přistupovat k datům v ":memory:"
. Nakonec DB Browser for SQLite není nutnost, určitě lze mezivýsledky dotazů zobrazit pohodlně jinou cestou.
Ale musel jsem dělat chybu ještě v něčem jiném, podle uvedeného dotazu jsem postupoval (spíš se pokoušel), ale něco jsem tam zoslil, a pak pro oči neviděl co.Takže ano, ačkoliv jsem odkaz znal, nefungovalo mi to . Teď už vím, že problém byl v csv souboru, původně jsem chybovou hlášku přehlédl jako širé rodné lány . Přiložený csv soubor je pouze fragmentem zdrojových dat. Některé záznamy v .ics souboru, z něhož je csv generován, se týkaly opakovaných událostí. Ty nebyly při úpravě textu dostatečně ošetřeny, resp. neměly se v kalendáři vůbec vyskytovat, proto se tato část úpravy ics měla řešit později.
python nn.py
funguje,
python3 nnn.py
nefunguje,
./nnn.py
také nefunguje; chnod 777 ./nnn.py
jsem zadal;resp. funguje pokud v prvnímřádku smažu číslici 3
.
#!/usr/bin/python3 import csv, sqlite3 con = sqlite3.connect(":memory:") cur = con.cursor() cur.execute("CREATE TABLE tt (ID_zak,zak_jmeno,zak_ulice,zak_mesto,zak_telefon,zak_mail,zak_ucet);") with open('zak.csv', 'r') as zak: dr = csv.reader(zak) for row in dr: to_db = [unicode(row[0],"utf8"), unicode(row[1],"utf8"), unicode(row[2],"utf8"), unicode(row[3],"utf8"), unicode(row[4],"utf8"), unicode(row[5],"utf8"), unicode(row[6],"utf8")] con.execute("INSERT INTO tt (ID_zak,zak_jmeno,zak_ulice,zak_mesto,zak_telefon,zak_mail,zak_ucet) VALUES (?,?,?,?,?,?,?);", to_db) con.commit() con.close()Python 3 má problém s unicode, tedy spíš s tím mým kódem, nevidíte někdo místo kde jsem mimo, děkuji.
unicode(row[x],"utf8")
na row[x]
Tiskni Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.