Portál AbcLinuxu, 12. listopadu 2025 19:56
, nejsem sto v Pythonu3 korektně dostat csv soubor do databáze, max. poslední řádek. Ať už db, včetně tabulky, vytvořím samostatně nebo v rámci skriptu, kde importuji
. Můžete mne, prosím, nasměrovat, děkuji předem.
Ř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.