Python & Sqlite

Pyyttoni

Aloittelijana olen yrittänyt sovittaa tkinter GUI:ta käyttämään sqlite tietokantaa mutta...
Esimerkkejä olen yrittänyt googlettaa mutta vaikeaa on sekin. Onko tiedossa hyviä malleja?
Aiemminkin on ollut mainintaa aloittaa tänne python osio...
Kiittäen :)

13

597

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • hjdsjhhjl

      Ei niitä varsinaisesti soviteta yhteen, sen kuin vain käyttää niitä. Vähän niinkuin jos menee ruokakauppaan ja samalla soittaa kännykällä... aivan eri asioita siis...

      • ssdfsdf

        Parempi kun pitää tietokannan, ohjelman ja käyttöliittymän erillään. Aina helpompi sitten muuttaa jotakin kun ei ole liikaa "sovitettu yhteen".


    • a---b+++

      Mitä oikein tarkoitat? Selvennä vähän että mitä yrität tehdä.

      • Pyyttoni

        Tkinterillä osaan vähän entryjä ja nappuloita käsitellä sekä sqliteä olen juuri koettanut opetella. Tarkoitus olisi luoda python-formi jolla sqlite-tietokantaa muokattaisi.
        Molempia olen pyörittänyt Python Shellissä ja pääteikkunassa mutta miten tuoda tkinter entryyn sqlite-haku?
        Opettelun tässä vaiheessa varsin pienikin esimerkki auttaisi.
        Onkohan nyt asioista kerrottu oikeilla nimillä?


      • fffffiiiuuuu
        Pyyttoni kirjoitti:

        Tkinterillä osaan vähän entryjä ja nappuloita käsitellä sekä sqliteä olen juuri koettanut opetella. Tarkoitus olisi luoda python-formi jolla sqlite-tietokantaa muokattaisi.
        Molempia olen pyörittänyt Python Shellissä ja pääteikkunassa mutta miten tuoda tkinter entryyn sqlite-haku?
        Opettelun tässä vaiheessa varsin pienikin esimerkki auttaisi.
        Onkohan nyt asioista kerrottu oikeilla nimillä?

        Harjoittele ennemmin yksi asia kerrallaan. Näyttää siltä että koitat kerralla opetella pythonia, graafisen käyttöliittymän tekoa (tosin tkinter on tässä tapauksessa varmaan niistä se helpoin) ja sitten tietokantaohjelmointia samaan aikaan.

        Vaikka sqliten käyttö onkin periaatteessa hyvin helppoa, tuo se vain turhaan ylimääräisen keskittymistä vievän tekijän tuossa vaiheessa. Tämä on vain mielipide.

        Voit harjoitella sqlite kyselyitä vaikkapa pythonin interaktiivisessa tulkissa aika näppärästi. Sitten vastaavien hakujen käyttö lomakkeilla yms on aika helppoa

        Tässä esimerkki simppelistä tietokannan luonnista, tietojen lisäyksestä ja sieltä selectillä hakemisesta. Todellisessa tilanteessa tuskin tekisit kaikkea yhdessä pötkössä :) toivottavasti esimerkki nyt ulostuu suomi24 oikein.. yritin laittaa entiteeteillä mut en tiijä menikö oikein

        import sqlite3
        c = sqlite3.connect(':memory:') # esimerkissä tietokanta vain muistissa
        cursor = c.cursor()
        cursor.execute('''create table henkilo (
        id integer primary key,
        nimi text not null,
        ika integer)''')
        daatta = [('Keijo', 20), ('Epeli', 21), ('Tarja', 16), ('Nykanen', 45), ('Tuksu', 666)]
        for a, b in daatta:
            print "viedaan henkilon tiedot kantaan: %s %sv" % (a, b)
            cursor.execute('insert into henkilo (nimi, ika) values (?, ?)', [a, b])
        print 'luetaan tiedot tietokannasta ikajarjestyksessa..'
        cursor.execute("select id, nimi, ika from henkilo order by ika asc")
        tulokset = cursor.fetchall()
        for tulos in tulokset:
            print tulos


      • Sama vauva-pyyttoni
        fffffiiiuuuu kirjoitti:

        Harjoittele ennemmin yksi asia kerrallaan. Näyttää siltä että koitat kerralla opetella pythonia, graafisen käyttöliittymän tekoa (tosin tkinter on tässä tapauksessa varmaan niistä se helpoin) ja sitten tietokantaohjelmointia samaan aikaan.

        Vaikka sqliten käyttö onkin periaatteessa hyvin helppoa, tuo se vain turhaan ylimääräisen keskittymistä vievän tekijän tuossa vaiheessa. Tämä on vain mielipide.

        Voit harjoitella sqlite kyselyitä vaikkapa pythonin interaktiivisessa tulkissa aika näppärästi. Sitten vastaavien hakujen käyttö lomakkeilla yms on aika helppoa

        Tässä esimerkki simppelistä tietokannan luonnista, tietojen lisäyksestä ja sieltä selectillä hakemisesta. Todellisessa tilanteessa tuskin tekisit kaikkea yhdessä pötkössä :) toivottavasti esimerkki nyt ulostuu suomi24 oikein.. yritin laittaa entiteeteillä mut en tiijä menikö oikein

        import sqlite3
        c = sqlite3.connect(':memory:') # esimerkissä tietokanta vain muistissa
        cursor = c.cursor()
        cursor.execute('''create table henkilo (
        id integer primary key,
        nimi text not null,
        ika integer)''')
        daatta = [('Keijo', 20), ('Epeli', 21), ('Tarja', 16), ('Nykanen', 45), ('Tuksu', 666)]
        for a, b in daatta:
            print "viedaan henkilon tiedot kantaan: %s %sv" % (a, b)
            cursor.execute('insert into henkilo (nimi, ika) values (?, ?)', [a, b])
        print 'luetaan tiedot tietokannasta ikajarjestyksessa..'
        cursor.execute("select id, nimi, ika from henkilo order by ika asc")
        tulokset = cursor.fetchall()
        for tulos in tulokset:
            print tulos

        Kiitos fffffiiiuuuu että olet ainakin vähän mukana. Esimerkkisi toimii kyllä hienosti.
        Olen jo tässä vaiheessa(muutama päivä sqliteä) kanssasi samaa mieltä että sqliten käyttö perusjutuilla ainakin on melko helppoa. Ehkä juuri siksi haluaisinkin laajentaa hommaa.
        Pythonin opiskelussa varmasti onkin tekemistä vaikka sekin perusteiltaan on melko selkeää. Kunnioitan syvästi teitä guruja...
        Minä itse (49v) en ole tietotekniikan alalla kovin kokenut (excel ja Oo.calc taipuu aika hyvin) mutta haluja kyllä on ja illat menee näitä pyöritellessä.
        Varmasti muillakin on sama näkemys että asiaa on helpompi viedä eteenpäin kun on selkeä päämäärä. Minulla se olisi melko laajakin tietokantaa pöyhivä itsenäinen ohjelma mutta pienillä jutuilla saisi perusteisiin vinkkejä.
        -Tosi hyvä malli olisi esim. fffffiiiuuuu:n juttu omasta Tk-ikkunasta käytettynä...


      • ffsfssww
        Sama vauva-pyyttoni kirjoitti:

        Kiitos fffffiiiuuuu että olet ainakin vähän mukana. Esimerkkisi toimii kyllä hienosti.
        Olen jo tässä vaiheessa(muutama päivä sqliteä) kanssasi samaa mieltä että sqliten käyttö perusjutuilla ainakin on melko helppoa. Ehkä juuri siksi haluaisinkin laajentaa hommaa.
        Pythonin opiskelussa varmasti onkin tekemistä vaikka sekin perusteiltaan on melko selkeää. Kunnioitan syvästi teitä guruja...
        Minä itse (49v) en ole tietotekniikan alalla kovin kokenut (excel ja Oo.calc taipuu aika hyvin) mutta haluja kyllä on ja illat menee näitä pyöritellessä.
        Varmasti muillakin on sama näkemys että asiaa on helpompi viedä eteenpäin kun on selkeä päämäärä. Minulla se olisi melko laajakin tietokantaa pöyhivä itsenäinen ohjelma mutta pienillä jutuilla saisi perusteisiin vinkkejä.
        -Tosi hyvä malli olisi esim. fffffiiiuuuu:n juttu omasta Tk-ikkunasta käytettynä...

        Äääh, en ole tuota tk itse käyttänyt eikä nyt viitsi alkaa opettelemaan :)

        Ei sillä ole väliä minkälaisesta käyttöliittymästä niitä tietokantakutsuja tehdään. Suosittelisin, että teet ensin valmiiksitietokantaluokan/moduulin ja tuon käyttöliittymän lomakkeen ja lopuksi sitten vain sovitat ne yhteen.

        Eli tässä tapauksessa teet vaikkapa yksinkertaisen Henkilo luokan, joka hallitsee ne tietokantatoiminnallisuudet mita tarvitset (vaikkapa henkilöiden lisäys, poisto ja haku). Sitten kun tämä toimii konsolista, niin se on helppo siirtää lomakkeen käytettäväksi. Etuna tämän toiminnallisuuden jakamiseen omaan luokkaan/moduuliin on se että toiminnot on määritelty yhteen paikkaan. Jos teet sql kyselyt jokaisessa näppäimen käsittelijässä lomakkella erikseen, niin sama toiminnallisuus tulee äkkiä kirjoitettua moneen paikkaan ja ylläpito menee hankalaksi.

        Käyttöliittymänkin voit toki tehdä ensin. Teet lomakkeen jossa on kaikki kentät ja painikkeet joita tarvitset. Tässä vaiheessa painikkeiden toiminnot ei tarvitse olla mitään todellisia vaan ne voivat tulostaa vaikka "lisää nappia painettu" ja näet että siltä osin koodi toimii.

        Sitten kun molemmat palikat toimivat päivität lomakeesi käyttämään tekemääsi Henkilöluokkaa ja voila!


    • Anonyymi

      Joskus tein tuon niin, että Tkinter-käyttöliittymä oli sovelluksessa omana luokkanaan ja tietokantatoiminnot omanaan. Käyttöliittymäluokasta sitten kutsuttiin tarvittaessa tietokantatoimintoja.

      • Anonyymi

        Minä en ole osannut arvostaa Tkinter käyttöliittymää siitä lähtien kun tajusin kuinka hankalaa sillä on tuottaa siisti liittymä python ohjelmalle. Itse asiassa sqlite3 ja python yhdistelmän soveltaminen on ollut niin vähäistä että kaiken joutuisin opettelemaan uudestaan. Mielenkiintoa asia kohtaan löytyy, keksisi vaan motivoivan tarpeen luoda luoda tietokanta sovellus pythonilla.


      • Anonyymi
        Anonyymi kirjoitti:

        Minä en ole osannut arvostaa Tkinter käyttöliittymää siitä lähtien kun tajusin kuinka hankalaa sillä on tuottaa siisti liittymä python ohjelmalle. Itse asiassa sqlite3 ja python yhdistelmän soveltaminen on ollut niin vähäistä että kaiken joutuisin opettelemaan uudestaan. Mielenkiintoa asia kohtaan löytyy, keksisi vaan motivoivan tarpeen luoda luoda tietokanta sovellus pythonilla.

        Tkinter on aika helppo, kun sen vaan oivaltaa. Minulla oli tietokantana MySQL, mutta periaate on sama kuin muillakin tietokannoilla. Tällä hetkellä tulee käytettyä enemmän NoSQL:ää, kuten MongoDB:tä.


      • Anonyymi
        Anonyymi kirjoitti:

        Minä en ole osannut arvostaa Tkinter käyttöliittymää siitä lähtien kun tajusin kuinka hankalaa sillä on tuottaa siisti liittymä python ohjelmalle. Itse asiassa sqlite3 ja python yhdistelmän soveltaminen on ollut niin vähäistä että kaiken joutuisin opettelemaan uudestaan. Mielenkiintoa asia kohtaan löytyy, keksisi vaan motivoivan tarpeen luoda luoda tietokanta sovellus pythonilla.

        Framet helpottaa aika paljon käyttöliittymän suunnittelua, kun niihin saa niputettua käyttöliittymän komponentteja, ja sitten aseteltua näitä ryhmiä haluamiinsa kohtiin.

        Tuossa yksi esimerkki Notepadin replace-ikkunan tapaisesta palikasta:

        https://www.pythontutorial.net/tkinter/tkinter-frame/


      • Anonyymi
        Anonyymi kirjoitti:

        Framet helpottaa aika paljon käyttöliittymän suunnittelua, kun niihin saa niputettua käyttöliittymän komponentteja, ja sitten aseteltua näitä ryhmiä haluamiinsa kohtiin.

        Tuossa yksi esimerkki Notepadin replace-ikkunan tapaisesta palikasta:

        https://www.pythontutorial.net/tkinter/tkinter-frame/

        Ihan tosissaanko te vielä tuota jaksatte opetella.


      • Anonyymi
        Anonyymi kirjoitti:

        Ihan tosissaanko te vielä tuota jaksatte opetella.

        Ei kannattaisi tuhlata aikaansa moiseen muinaisjäänteeseen.


    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. Miksi persuilla ei ole firmoja?

      Kuten vasemmisstolaisilla, esim. Sannalla MA\PI. Eikö ole aika erikoista?
      Maailman menoa
      84
      7132
    2. Persut hommasivat Suomeen 35 000 pientä lasta v. 2015

      Onko Riikka Purra nyt tavoittelemassa tätä samaa historiallista persujen utopiaa? Purram kaksinaamaisessa pelissä vaadit
      Maailman menoa
      27
      7079
    3. Purran tuhoja tuskin saadaan koskaan korjatuksikaan

      Purra on aiheuttanut Suomen taloudelle karmaisevat tuhot. Sen lisäksi Purra on ajanut myös suuren osan Suomen kansasta k
      Maailman menoa
      117
      6215
    4. Persujen kaksoisstandardit: Räsäsen uhkailu paha, Virran uhkailu hyvä

      Tässä taas nähdään kuinka kaksinaamaista porukkaa persut ovat. Mitäs persut tähän?
      Maailman menoa
      45
      5414
    5. Miksette persut irtisanoudu Kirkin lausunnoista?

      Kirkhän muun muassa vaati raiskattuja naisia pidättäytymään abortista ja vaimoja alistumaan aviomiestensä tahtoon. Mik
      Maailman menoa
      84
      5318
    6. Demarikultin uhri kertoo

      Demarikultin uhri kertoo: “En saanut mennä edes suihkuun ilman lupaa” – Seksuaalisen hyväksikäytön uhri kertoo vuosistaa
      Maailman menoa
      63
      5225
    7. Miksi vasemmistolaiset eivät omista yhtään firmaa?

      Vasemmistolaiset eivät omista yhtään firmaa joka työllistäisi ihmisiä. Miksi? No siksi, että jos vasemmistolainen perus
      Maailman menoa
      41
      5120
    8. Sanna valittiin Euroopan huonoimmaksi pääministeriksi

      Sannan kaudella Suomi oli ainut maa missä bkt laski. Kannattaa huomata, että luvut valitsi Sannan huonoimmaksi. Ihmiset
      Maailman menoa
      27
      4605
    9. Purran vuoro kiihoittua Lepomäen sääristä

      "Ulkoministeri Elina sanoo, ettei muuta pukeutumistaan sen mukaan, kenet tapaa, ja että hän ei suostuisi peittämään kasv
      Maailman menoa
      19
      3555
    10. Vasemmistolaiset paskat eivät nousseet seisomaan kun Akaan kaupunginvaltuusto

      vietti hiljaisen hetken Charlie Kirkin muistoksi https://www.aamulehti.fi/uutiset/art-2000011523016.html
      Maailman menoa
      300
      3400
    Aihe