[python] wxPython - zobrazení dat z DB

Mix mix na svobodnik.cz
Sobota Březen 7 02:48:07 CET 2009


Dobrý den , nevím si s tím rady a tak vás chci požádat o pomoc.
mám data uložená v DB kde jsou sloupce ID, cilso1, cislo2, cislo3.
Potřebuji tyto data zobrazit v tabulce kde budou některé sloupce jen 
zobrazené a jiné bude možnost editovat.
Počet sloupců bude pevně dán, ale počet řádku bude pokaždé jiný. (viz 
ukázkový kód)
Takže jsem se chtěl zeptat jak tyto data řádek po řádku zobrazit. a po 
editaci je přes tlačítko "Ulozit" uložit zpět do databáze, aby se mě 
editovatelná pole uložila zpátky ke správnému řádku s daným ID. ukázka 
GUI je udělaná ve wxPythonu, ve které bych to chtěl udělat, Pokud si ale 
myslíte, že by to bylo jednoduší v Tkinter tak budu vděčný i za toto řešení.
děkuju
Pavel


#!/usr/bin/env python
# -*- coding: iso-8859-15 -*-
# generated by wxGlade 0.6.3 on Thu Mar 05 08:36:18 2009

import wx

class MyFrame(wx.Frame):
    def __init__(self, *args, **kwds):
        # begin wxGlade: MyFrame.__init__
        kwds["style"] = wx.DEFAULT_FRAME_STYLE
        wx.Frame.__init__(self, *args, **kwds)
        self.button_1 = wx.Button(self, -1, "Ulozit")
        self.label_1 = wx.StaticText(self, -1, "A")
        self.label_2_copy = wx.StaticText(self, -1, "B")
        self.label_3_copy = wx.StaticText(self, -1, "C")
        self.text_ctrl_1_copy = wx.TextCtrl(self, -1, "1,2", 
style=wx.TE_CENTRE)
        self.text_ctrl_12_copy = wx.TextCtrl(self, -1, "5,3", 
style=wx.TE_CENTRE)
        self.text_ctrl_11_copy = wx.TextCtrl(self, -1, "74", 
style=wx.TE_CENTRE)
        self.text_ctrl_10_copy = wx.TextCtrl(self, -1, "4444", 
style=wx.TE_CENTRE)
        self.text_ctrl_13_copy = wx.TextCtrl(self, -1, "12,3", 
style=wx.TE_CENTRE)
        self.text_ctrl_8_copy = wx.TextCtrl(self, -1, "10", 
style=wx.TE_CENTRE)
        self.text_ctrl_3_copy = wx.TextCtrl(self, -1, "214", 
style=wx.TE_CENTRE)
        self.text_ctrl_14_copy = wx.TextCtrl(self, -1, "999874", 
style=wx.TE_CENTRE)
        self.text_ctrl_9_copy = wx.TextCtrl(self, -1, "2", 
style=wx.TE_CENTRE)

        self.__set_properties()
        self.__do_layout()

        self.Bind(wx.EVT_BUTTON, self.ulo, self.button_1)
        # end wxGlade

    def __set_properties(self):
        # begin wxGlade: MyFrame.__set_properties
        self.SetTitle("frame_2")
        self.SetBackgroundColour(wx.Colour(255, 255, 0))
        self.text_ctrl_1_copy.Enable(False)
        self.text_ctrl_12_copy.Enable(False)
        self.text_ctrl_10_copy.Enable(False)
        self.text_ctrl_13_copy.Enable(False)
        self.text_ctrl_3_copy.Enable(False)
        self.text_ctrl_14_copy.Enable(False)
        # end wxGlade

    def __do_layout(self):

        sizer_1 = wx.BoxSizer(wx.VERTICAL)
        grid_sizer_2 = wx.GridSizer(5, 3, 2, 2)
        grid_sizer_2.Add(self.button_1, 0, 0, 5)
        grid_sizer_2.Add((20, 20), 0, 0, 0)
        grid_sizer_2.Add((20, 20), 0, 0, 0)
        grid_sizer_2.Add(self.label_1, 0, 
wx.ALIGN_BOTTOM|wx.ALIGN_CENTER_HORIZONTAL, 0)
        grid_sizer_2.Add(self.label_2_copy, 0, 
wx.ALIGN_BOTTOM|wx.ALIGN_CENTER_HORIZONTAL, 0)
        grid_sizer_2.Add(self.label_3_copy, 0, 
wx.ALIGN_BOTTOM|wx.ALIGN_CENTER_HORIZONTAL, 0)
        grid_sizer_2.Add(self.text_ctrl_1_copy, 0, 0, 0)
        grid_sizer_2.Add(self.text_ctrl_12_copy, 0, 0, 0)
        grid_sizer_2.Add(self.text_ctrl_11_copy, 0, 0, 0)
        grid_sizer_2.Add(self.text_ctrl_10_copy, 0, 0, 0)
        grid_sizer_2.Add(self.text_ctrl_13_copy, 0, 0, 0)
        grid_sizer_2.Add(self.text_ctrl_8_copy, 0, 0, 0)
        grid_sizer_2.Add(self.text_ctrl_3_copy, 0, 0, 0)
        grid_sizer_2.Add(self.text_ctrl_14_copy, 0, 0, 0)
        grid_sizer_2.Add(self.text_ctrl_9_copy, 0, 0, 0)
        sizer_1.Add(grid_sizer_2, 1, wx.EXPAND, 0)
        self.SetSizer(sizer_1)
        sizer_1.Fit(self)
        self.Layout()

    def ulo(self, event): # wxGlade: MyFrame.<event_handler>
        print "Event handler `ulo' not implemented"
        event.Skip()

class MyApp(wx.App):
    def OnInit(self):
        wx.InitAllImageHandlers()
        frame_1 = MyFrame(None, -1, "")
        self.SetTopWindow(frame_1)
        frame_1.Show()
        return 1

if __name__ == "__main__":
    app = MyApp(0)
    app.MainLoop()


Další informace o konferenci Python