[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