第20天 | 25天学会wxPython,高级组件之电子表格

高级组件不是说这个组件有多”高级”的意思,而是表示功能强大的意思。如要实现一个功能完整的表格功能,可能需要花上好几天,编写好多代码才能实现,而直接调用wx.Grid组件,三两下就搞定了,所以说这个组件很高级。

wxPython常用的高级组件有表格wx.grid.Grid、多项列表wx.ListCtrl和树状结构wx.TreeCtrl组件。

20.1 电子表格

电子表格可以输入输出、显示数据,也利用公式计算一些简单的加减法。可以帮助用户制作各种复杂的表格文档,进行繁琐的数据计算,并能对输入的数据进行各种复杂统计运算后显示为可视性极佳的表格。将表格组件wx.grid.Grid,理解成小型的excel就好了。

程序清单:grid.py

import wx
import wx.grid


# 继承Frame
class GridControl(wx.Frame):

    def __init__(self, *args, **kwargs):
        super(GridControl, self).__init__(*args, **kwargs)
        # 初始化窗口UI
        self.init_ui()

    def init_ui(self):
        h_box = wx.BoxSizer(wx.HORIZONTAL)
        # 面板
        panel = wx.Panel(self)
        # 表格
        grid = wx.grid.Grid(panel, id=wx.ID_ANY, size=(900, 500))
        # 创建一个25X15的电子表格
        grid.CreateGrid(25, 25)
        # 第1行数据
        grid.SetCellValue(0, 0, "员工姓名")
        grid.SetCellValue(0, 1, "编号")
        grid.SetCellValue(0, 2, "性别")
        grid.SetCellValue(0, 3, "生日")
        # 第2行数据
        grid.SetCellValue(1, 0, "西门吹水")
        grid.SetCellValue(1, 1, "123456")
        grid.SetCellValue(1, 2, "男")
        grid.SetCellValue(1, 3, "1988-12-01")
        # 左单击
        grid.Bind(wx.grid.EVT_GRID_CELL_LEFT_CLICK, self.left_click)
        # 右双击
        grid.Bind(wx.grid.EVT_GRID_CELL_RIGHT_DCLICK, self.right_dbclick)
        h_box.Add(grid, proportion=1, flag=wx.EXPAND)
        panel.SetSizer(h_box)
        self.SetSize(900, 500)
        self.SetTitle("表格的应用")
        self.Centre()
        self.Show(True)

    def left_click(self, e):
        grid = e.GetEventObject()
        cell_value = grid.GetCellValue(e.GetRow(), e.GetCol())
        print(cell_value)

    def right_dbclick(self, e):
        grid = e.GetEventObject()
        cell_value = grid.GetCellValue(e.GetRow(), e.GetCol())
        print(cell_value)


def main():
    app = wx.App(False)
    GridControl(None)
    app.MainLoop()


if __name__ == "__main__":
    main()

运行程序之后,弹出的窗口如下:

第20天 | 25天学会wxPython,高级组件之电子表格

表格组件wx.grid.Grid,通过CreateGrid()方法指定表格的行数和列表,SetCellValue(row, col, s)方法往单元格里写入数据;通过GridEvent对象的GetRow()和GetCol()方法,可以获得点击所在的行和列。Grid的方法和参数有点多,更多详细内容,你可以上wxPython的官网进一步了解。

好了,高级组件之电子表格的内容就说到这了,关注我,下一节更精彩。

码字不易,你的关注和转发是对我最大的鼓励,谢谢!

一个当了10年技术总监的老家伙,分享多年的编程经验。想学编程的朋友,关注我,你就赚到了。我正在分享Python、前端、Java和App方面的干货了。赶紧来围观啊!!!

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值