【问题标题】:wxpython: Updating a dict or other appropriate data type from wx.lib.sheet.CSheet objectwxpython:从 wx.lib.sheet.CSheet 对象更新字典或其他适当的数据类型
【发布时间】:2010-09-24 14:07:03
【问题描述】:

如果我有一个带有三个电子表格小部件的笔记本,那么让电子表格的更改更新字典(或者可能是一个 sqlite 文件?)的最佳方法是什么。是否所有 wx 网格对象都带有与 SetNumberRows 和 SetNumberCols 相关的内置字典?基本上,我正在寻找有关如何使用电子表格小部件中的用户输入数据的指导,如本示例改编自 python.org 上的教程:

class ExSheet(wx.lib.sheet.CSheet):
    def __init__(self, parent):
        sheet.CSheet.__init__(self, parent)
        self.SetLabelBackgroundColour('#CCFF66')
        self.SetNumberRows(50)
        self.SetNumberCols(50)

class Notebook(wx.Frame):
    def __init__(self, parent, id, title):
        wx.Frame.__init__(self, parent, id, title)
        nb = wx.Notebook(self, -1, style=wx.NB_BOTTOM)
        self.sheet1 = ExSheet(nb)
        self.sheet2 = ExSheet(nb)
        self.sheet3 = ExSheet(nb)
        nb.AddPage(self.sheet1, "Sheet1")
        nb.AddPage(self.sheet2, "Sheet2")
        nb.AddPage(self.sheet3, "Sheet3")
        self.sheet1.SetFocus()
        self.StatusBar()

【问题讨论】:

    标签: python wxpython spreadsheet wxwidgets


    【解决方案1】:

    使用 wxGridwxGridTableBase 代替

    这是一个简单的例子:

    import wx, wx.grid
    
    class GridData(wx.grid.PyGridTableBase):
        _cols = "a b c".split()
        _data = [
            "1 2 3".split(),
            "4 5 6".split(),
            "7 8 9".split()
        ]
    
        def GetColLabelValue(self, col):
            return self._cols[col]
    
        def GetNumberRows(self):
            return len(self._data)
    
        def GetNumberCols(self):
            return len(self._cols)
    
        def GetValue(self, row, col):
            return self._data[row][col]
    
        def SetValue(self, row, col, val):
            self._data[row][col] = val
    
    class Test(wx.Frame):
        def __init__(self):
            wx.Frame.__init__(self, None)
            self.data = GridData()
            grid = wx.grid.Grid(self)
            grid.SetTable(self.data)
            self.Bind(wx.EVT_CLOSE, self.OnClose)
            self.Show()
    
        def OnClose(self, event):
            print self.data._data
            event.Skip()
    
    app = wx.PySimpleApp()
    app.TopWindow = Test()
    app.MainLoop()
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-11-27
      • 1970-01-01
      • 2012-01-30
      • 1970-01-01
      • 2018-08-05
      • 2019-01-15
      相关资源
      最近更新 更多