wxPython电子表格功能wx.grid实例教程

 更新时间:2019年11月19日 10:48:00   作者:卡图卢斯  
这篇文章主要介绍了wxPython电子表格功能wx.grid实例教程,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了wxPython电子表格功能的具体代码,供大家参考,具体内容如下

#!/usr/bin/env python
#encoding: utf8 
import wx
import wx.grid as gridlib
#import wx.lib.mixins.grid as mixins

#---------------------------------------------------------------------------

class SimpleGrid(gridlib.Grid): ##, mixins.GridAutoEditMixin):
  def __init__(self, parent, log):
    gridlib.Grid.__init__(self, parent, -1)
    ##mixins.GridAutoEditMixin.__init__(self)
    #打印log信息
    self.log = log
    self.moveTo = None

    self.Bind(wx.EVT_IDLE, self.OnIdle)
    #创建一个25X25的电子表格
    self.CreateGrid(25, 25)#, gridlib.Grid.SelectRows)
    ##self.EnableEditing(False)

    #simple cell formatting
    #设置第index=3列的宽度大小,像素=200
    self.SetColSize(col=3,width=200)
    #设置第index=4行的高度大小,像素=45
    self.SetRowSize(4, 45)
    #设置 row=0,col=0,value="First cell"
    self.SetCellValue(0, 0, "First cell")
    #设置 row=1,col=1,value="Another cell"
    self.SetCellValue(1, 1, "Another cell")
    #设置 row=2,col=2,value="Yet another cell"
    self.SetCellValue(2, 2, "Yet another cell")
    #设置 row=3,col=3,value="This cell is read-only"
    self.SetCellValue(3, 3, "This cell is read-only")
    #设置字体格式
    self.SetCellFont(0, 0, wx.Font(12, wx.FONTFAMILY_ROMAN, wx.FONTSTYLE_ITALIC, wx.FONTWEIGHT_NORMAL))
    #设置字体颜色
    self.SetCellTextColour(1, 1, wx.RED)
    #设置cell背景颜色
    self.SetCellBackgroundColour(2, 2, wx.CYAN)
    #设置只读属性
    self.SetReadOnly(3, 3, True)
    #设置 row=5,col=0,数字编辑器
    self.SetCellEditor(5, 0, gridlib.GridCellNumberEditor(1,1000))
    #设置 row=5,col=0,value="123"
    self.SetCellValue(5, 0, "123")
    #设置 row=6,col=0,浮点数
    self.SetCellEditor(6, 0, gridlib.GridCellFloatEditor())
    #设置 row=6,col=0,value="123.34"
    self.SetCellValue(6, 0, "123.34")
    #设置
    self.SetCellEditor(7, 0, gridlib.GridCellNumberEditor())
    #设置 row=6,col=3,value="You can veto editing this cell"
    self.SetCellValue(6, 3, "You can veto editing this cell")

    #self.SetRowLabelSize(0)
    #self.SetColLabelSize(0)

    # attribute objects let you keep a set of formatting values
    # in one spot, and reuse them if needed
    #wx.grid.GridCellAttr

    #这个类可以用来通过改变它们的默认属性来改变网格在网格中的外观。
    attr = gridlib.GridCellAttr()
    #字体颜色:黑色
    attr.SetTextColour(wx.BLACK)
    #设置背景颜色:红色
    attr.SetBackgroundColour(wx.RED)
    #设置字体格式
    attr.SetFont(wx.Font(10, wx.FONTFAMILY_SWISS, wx.FONTSTYLE_NORMAL, wx.FONTWEIGHT_BOLD))

    # you can set cell attributes for the whole row (or column)
    #设置Row=5,attr
    self.SetRowAttr(5, attr)

    #设置Col=0,LableValue =Custom
    self.SetColLabelValue(0, "Custom")
    #设置Col=1,LabelValue = "column"
    self.SetColLabelValue(1, "column")
    #设置Col=2,LabelValue = labels
    self.SetColLabelValue(2, "labels")
    #设置列表标签左右以及上下对齐方式:左对齐,下沉
    self.SetColLabelAlignment(wx.ALIGN_LEFT, wx.ALIGN_BOTTOM)

    #self.SetDefaultCellOverflow(False)
    #r = gridlib.GridCellAutoWrapStringRenderer()
    #self.SetCellRenderer(9, 1, r)

    #overflow cells
    self.SetCellValue( 9, 1, "This default cell will overflow into neighboring cells, but not if you turn overflow off.");
    #单元格合并处理:3x3
    self.SetCellSize(11, 1, 3, 3);
    #设置单元格对齐方式:中间,中间
    self.SetCellAlignment(11, 1, wx.ALIGN_CENTRE, wx.ALIGN_CENTRE);
    #设置单元格值
    self.SetCellValue(11, 1, "This cell is set to span 3 rows and 3 columns");

    #设置
    editor = gridlib.GridCellTextEditor()
    #值长度
    editor.SetParameters('10')
    #设置格式
    self.SetCellEditor(0, 4, editor)
    #设置值
    self.SetCellValue(0, 4, "Limited text")

    #可以用来格式化单元格中的字符串数据。
    renderer = gridlib.GridCellAutoWrapStringRenderer()
    self.SetCellRenderer(15,0, renderer)
    self.SetCellValue(15,0, "The text in this cell will be rendered with word-wrapping")


    # test all the events
    #左单击
    self.Bind(gridlib.EVT_GRID_CELL_LEFT_CLICK, self.OnCellLeftClick)
    #右单击
    self.Bind(gridlib.EVT_GRID_CELL_RIGHT_CLICK, self.OnCellRightClick)
    #左双击
    self.Bind(gridlib.EVT_GRID_CELL_LEFT_DCLICK, self.OnCellLeftDClick)
    #右双击
    self.Bind(gridlib.EVT_GRID_CELL_RIGHT_DCLICK, self.OnCellRightDClick)

    #label 左单击
    self.Bind(gridlib.EVT_GRID_LABEL_LEFT_CLICK, self.OnLabelLeftClick)
    #label 右单击
    self.Bind(gridlib.EVT_GRID_LABEL_RIGHT_CLICK, self.OnLabelRightClick)
    #label 左双击
    self.Bind(gridlib.EVT_GRID_LABEL_LEFT_DCLICK, self.OnLabelLeftDClick)
    #label 右双击
    self.Bind(gridlib.EVT_GRID_LABEL_RIGHT_DCLICK, self.OnLabelRightDClick)


    self.Bind(gridlib.EVT_GRID_COL_SORT, self.OnGridColSort)

    #拖动Row大小
    self.Bind(gridlib.EVT_GRID_ROW_SIZE, self.OnRowSize)
    #拖动Col大小
    self.Bind(gridlib.EVT_GRID_COL_SIZE, self.OnColSize)

    self.Bind(gridlib.EVT_GRID_RANGE_SELECT, self.OnRangeSelect)
    self.Bind(gridlib.EVT_GRID_CELL_CHANGED, self.OnCellChange)
    self.Bind(gridlib.EVT_GRID_SELECT_CELL, self.OnSelectCell)

    self.Bind(gridlib.EVT_GRID_EDITOR_SHOWN, self.OnEditorShown)
    self.Bind(gridlib.EVT_GRID_EDITOR_HIDDEN, self.OnEditorHidden)
    self.Bind(gridlib.EVT_GRID_EDITOR_CREATED, self.OnEditorCreated)


  def OnCellLeftClick(self, evt):
    self.log.write("OnCellLeftClick: (%d,%d) %s\n" %
            (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
    evt.Skip()

  def OnCellRightClick(self, evt):
    self.log.write("OnCellRightClick: (%d,%d) %s\n" %
            (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
    evt.Skip()

  def OnCellLeftDClick(self, evt):
    self.log.write("OnCellLeftDClick: (%d,%d) %s\n" %
            (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
    evt.Skip()

  def OnCellRightDClick(self, evt):
    self.log.write("OnCellRightDClick: (%d,%d) %s\n" %
            (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
    evt.Skip()

  def OnLabelLeftClick(self, evt):
    self.log.write("OnLabelLeftClick: (%d,%d) %s\n" %
            (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
    evt.Skip()

  def OnLabelRightClick(self, evt):
    self.log.write("OnLabelRightClick: (%d,%d) %s\n" %
            (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
    evt.Skip()

  def OnLabelLeftDClick(self, evt):
    self.log.write("OnLabelLeftDClick: (%d,%d) %s\n" %
            (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
    evt.Skip()

  def OnLabelRightDClick(self, evt):
    self.log.write("OnLabelRightDClick: (%d,%d) %s\n" %
            (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
    evt.Skip()

  def OnGridColSort(self, evt):
    self.log.write("OnGridColSort: %s %s" % (evt.GetCol(), self.GetSortingColumn()))
    self.SetSortingColumn(evt.GetCol())

  def OnRowSize(self, evt):
    self.log.write("OnRowSize: row %d, %s\n" %
            (evt.GetRowOrCol(), evt.GetPosition()))
    evt.Skip()

  def OnColSize(self, evt):
    self.log.write("OnColSize: col %d, %s\n" %
            (evt.GetRowOrCol(), evt.GetPosition()))
    evt.Skip()

  def OnRangeSelect(self, evt):
    if evt.Selecting():
      msg = 'Selected'
    else:
      msg = 'Deselected'
    self.log.write("OnRangeSelect: %s top-left %s, bottom-right %s\n" %
              (msg, evt.GetTopLeftCoords(), evt.GetBottomRightCoords()))
    evt.Skip()


  def OnCellChange(self, evt):
    self.log.write("OnCellChange: (%d,%d) %s\n" %
            (evt.GetRow(), evt.GetCol(), evt.GetPosition()))

    # Show how to stay in a cell that has bad data. We can't just
    # call SetGridCursor here since we are nested inside one so it
    # won't have any effect. Instead, set coordinates to move to in
    # idle time.
    value = self.GetCellValue(evt.GetRow(), evt.GetCol())

    if value == 'no good':
      self.moveTo = evt.GetRow(), evt.GetCol()


  def OnIdle(self, evt):
    if self.moveTo != None:
      self.SetGridCursor(self.moveTo[0], self.moveTo[1])
      self.moveTo = None

    evt.Skip()


  def OnSelectCell(self, evt):
    if evt.Selecting():
      msg = 'Selected'
    else:
      msg = 'Deselected'
    self.log.write("OnSelectCell: %s (%d,%d) %s\n" %
            (msg, evt.GetRow(), evt.GetCol(), evt.GetPosition()))

    # Another way to stay in a cell that has a bad value...
    row = self.GetGridCursorRow()
    col = self.GetGridCursorCol()

    if self.IsCellEditControlEnabled():
      self.HideCellEditControl()
      self.DisableCellEditControl()

    value = self.GetCellValue(row, col)

    if value == 'no good 2':
      return # cancels the cell selection

    evt.Skip()


  def OnEditorShown(self, evt):
    if evt.GetRow() == 6 and evt.GetCol() == 3 and \
      wx.MessageBox("Are you sure you wish to edit this cell?",
            "Checking", wx.YES_NO) == wx.NO:
      evt.Veto()
      return

    self.log.write("OnEditorShown: (%d,%d) %s\n" %
            (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
    evt.Skip()


  def OnEditorHidden(self, evt):
    if evt.GetRow() == 6 and evt.GetCol() == 3 and \
      wx.MessageBox("Are you sure you wish to finish editing this cell?",
            "Checking", wx.YES_NO) == wx.NO:
      evt.Veto()
      return

    self.log.write("OnEditorHidden: (%d,%d) %s\n" %
            (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
    evt.Skip()


  def OnEditorCreated(self, evt):
    self.log.write("OnEditorCreated: (%d, %d) %s\n" %
            (evt.GetRow(), evt.GetCol(), evt.GetControl()))



#---------------------------------------------------------------------------

class TestFrame(wx.Frame):
  def __init__(self, parent, log):
    wx.Frame.__init__(self, parent, -1, "Simple Grid Demo", size=(640,640))
    self.grid = SimpleGrid(self, log)



#---------------------------------------------------------------------------

if __name__ == '__main__':
  import sys
  print("hhh!!!")
  sys.stdout.write("hll"+"\n")
  if(0):#this section is modified by tony
    from wx.lib.mixins.inspection import InspectableApp
    app = InspectableApp(False)
  else:
    app = wx.App(False)
  frame = TestFrame(None, sys.stdout)
  if(0):#this section is modified by tony
    print(sys.stdout)
    print(type(sys.stdout))
  frame.Show(True)
  #import wx.lib.inspection
  #wx.lib.inspection.InspectionTool().Show()
  app.MainLoop()


#---------------------------------------------------------------------------

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • python+appium+yaml移动端自动化测试框架实现详解

    python+appium+yaml移动端自动化测试框架实现详解

    这篇文章主要介绍了python+appium+yaml移动端自动化测试框架实现详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Python实现拼接多张图片的方法

    Python实现拼接多张图片的方法

    这篇文章主要介绍了Python实现拼接多张图片的方法,以具体的实际应用引出Python拼接图片的思路并给出了实现的具体方法,需要的朋友可以参考下
    2014-12-12
  •  Python思维导图汇总

     Python思维导图汇总

    这篇文章主要给大家分享的是 Python思维导图汇总,对大家学习或工作或许有一定参考价值,需要的朋友可以参考一下,洗碗给对你有所帮助
    2022-01-01
  • Python动态规划实现虚拟机部署的算法思想

    Python动态规划实现虚拟机部署的算法思想

    这篇文章主要介绍了Python动态规划实现虚拟机部署的算法思想,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-07-07
  • Python使用QRCode模块生成二维码实例详解

    Python使用QRCode模块生成二维码实例详解

    这篇文章主要介绍了Python使用QRCode模块生成二维码实例详解的相关资料,需要的朋友可以参考下
    2017-06-06
  • Python实现的概率分布运算操作示例

    Python实现的概率分布运算操作示例

    这篇文章主要介绍了Python实现的概率分布运算操作,涉及Python概率运算与图形绘制相关操作技巧,需要的朋友可以参考下
    2017-08-08
  • python unichr函数知识点总结

    python unichr函数知识点总结

    在本篇文章里小编给大家整理的是一篇关于python unichr函数的知识点总结内容,有兴趣的朋友们可以学习下。
    2020-12-12
  • Python入门_浅谈逻辑判断与运算符

    Python入门_浅谈逻辑判断与运算符

    下面小编就为大家带来一篇Python入门_浅谈逻辑判断与运算符。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • 如何使用Python OpenCV提取物体轮廓详解

    如何使用Python OpenCV提取物体轮廓详解

    图像的轮廓检测不论是机器视觉还是其他方面都有较大作用,下面这篇文章主要给大家介绍了关于如何使用Python OpenCV提取物体轮廓的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-05-05
  • python3实现点餐系统

    python3实现点餐系统

    这篇文章主要为大家详细介绍了python3实现点餐系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01

最新评论