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


Posted in Python onNovember 19, 2019

本文实例为大家分享了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 相关文章推荐
python获取本机mac地址和ip地址的方法
Apr 29 Python
Python基于回溯法解决01背包问题实例
Dec 06 Python
Python自定义线程池实现方法分析
Feb 07 Python
Python定义二叉树及4种遍历方法实例详解
Jul 05 Python
Python查找文件中包含中文的行方法
Dec 19 Python
使用python读取.text文件特定行的数据方法
Jan 28 Python
selenium2.0中常用的python函数汇总
Aug 05 Python
python模拟点击网页按钮实现方法
Feb 25 Python
利用Python发送邮件或发带附件的邮件
Nov 12 Python
OpenCV-Python直方图均衡化实现图像去雾
Jun 07 Python
Pandas 稀疏数据结构的实现
Jul 25 Python
python区块链持久化和命令行接口实现简版
May 25 Python
python 实现return返回多个值
Nov 19 #Python
wxPython实现带颜色的进度条
Nov 19 #Python
Python使用Pandas读写Excel实例解析
Nov 19 #Python
pycharm修改file type方式
Nov 19 #Python
wxPython实现列表增删改查功能
Nov 19 #Python
python ctypes库2_指定参数类型和返回类型详解
Nov 19 #Python
Python 使用type来定义类的实现
Nov 19 #Python
You might like
关于php fread()使用技巧
2010/01/22 PHP
php 生成签名及验证签名详解
2016/10/26 PHP
javascript DOM编程实例(智播客学习)
2009/11/23 Javascript
分享20多个很棒的jQuery 文件上传插件或教程
2011/09/04 Javascript
javascript检测对象中是否存在某个属性判断方法小结
2013/05/19 Javascript
jquery实现增加删除行的方法
2015/02/03 Javascript
JavaScript中boolean类型之三种情景实例代码
2016/11/21 Javascript
jquery点击展示与隐藏更多内容
2016/12/03 Javascript
JS验证不重复验证码
2017/02/10 Javascript
微信小程序 引用其他js文件实现代码
2017/02/22 Javascript
bootstrap switch开关组件使用方法详解
2017/08/22 Javascript
javascript性能优化之分时函数的介绍
2018/03/28 Javascript
javascript设计模式 ? 抽象工厂模式原理与应用实例分析
2020/04/09 Javascript
vuex 多模块时 模块内部的mutation和action的调用方式
2020/07/24 Javascript
解决vux 中popup 组件Mask 遮罩在最上层的问题
2020/11/03 Javascript
[54:10]完美世界DOTA2联赛PWL S2 Magma vs FTD 第二场 11.29
2020/12/03 DOTA
urllib2自定义opener详解
2014/02/07 Python
python调用java的Webservice示例
2014/03/10 Python
采用python实现简单QQ单用户机器人的方法
2014/07/03 Python
Python3 正在毁灭 Python的原因分析
2014/11/28 Python
python中使用xlrd读excel使用xlwt写excel的实例代码
2018/01/31 Python
Python网络爬虫神器PyQuery的基本使用教程
2018/02/03 Python
使用pandas 将DataFrame转化成dict
2019/12/10 Python
如何定义TensorFlow输入节点
2020/01/23 Python
Python多线程获取返回值代码实例
2020/02/17 Python
Jupyter Notebook打开任意文件夹操作
2020/04/14 Python
python 读取.nii格式图像实例
2020/07/01 Python
python安装mysql的依赖包mysql-python操作
2021/01/01 Python
Dyson加拿大官方网站:购买戴森吸尘器,风扇,冷热器及配件
2016/10/26 全球购物
毕业自我鉴定
2013/11/05 职场文书
服装厂厂长职责
2013/12/16 职场文书
档案室主任岗位职责
2014/02/12 职场文书
海飞丝的广告词
2014/03/20 职场文书
大学生学年个人总结
2015/02/15 职场文书
锦旗赠语
2015/06/23 职场文书
索尼ICF-36收音机评测
2022/04/30 无线电