Python 学习之 Tkinter「下」

列表框控件:可以包含一个或者多个文本框。作用:在 ListBox 控件的小窗口显示项目列表

注意 selectmode 几种方式的区别:

1.BROWSE:通常,只能从列表框中选择一行。如果单击一个项目,然后拖动鼠标会跟随选中,是默认的。 2.SINGLE:和 BROWSE 的区别是你只能选择一行,不能拖动。 3.EXTENDED:通过 shift 和 control 可以使 ListBox 支持连选和多选,能拖动 4.MULTIPLE:支持连选和多选,但不能拖动

列表框 ListBox I

# 创建一个 listbox ,并向其中添加元素

lb = tkinter.Listbox(win, selectmode=tkinter.BROWSE)
lb.pack()

for i in ["man", "pig", "dog", "cat"]:
    lb.insert(tkinter.END, i)  # 按顺序依次往后添加元素

lb.insert(tkinter.ACTIVE, "chicken")  # 添加到开始的位置

# 将列表元素当做一个整体添加,不常用
lb.insert(tkinter.END, ["bird", "duck"])

# 删除元素:参数 1 为开始的引用,参数 2 为结束的索引,如果不指出参数 2 ,只删除第一个索引处的内容
lb.delete(1, 2)
lb.delete(1)

# 选中 用法同删除
lb.select_set(0, 1)

# 取消选中,用法同删除
lb.select_clear(0)

print(lb.size)  # 控制台返回元素个数

print(lb.get(0, 2))  # 获取元素值,用法同删除

print(lb.curselection())  # 返回当前的索引值

print(lb.selection_includes(1))  # 判断索引项是否被选中

效果图

列表框 ListBox II

# 绑定变量
v = tkinter.StringVar()

# SINGLE 与 BORWSE 相似,但是不支持鼠标按下后移动选中位置
lb = tkinter.Listbox(win, selectmode=tkinter.SINGLE, listvariable=v)
lb.pack()

for i in ["green", "blue", "yellow", "white"]:
    lb.insert(tkinter.END, i)  

print(v.get())  # 取出元组类型的数据 ('green', 'blue', 'yellow', 'white')

v.set(("one", "two", "three", "four"))  # 设置元素值

# 绑定事件 鼠标双击两次,控制台输出对应的列表项的值
def show(event):
    print(lb.get(lb.curselection()))

lb.bind('<Double-Button-1>', show)

效果图

列表框 ListBox III

# EXTENDED 通过 shift 和 control 可以使 ListBox 支持连选和多选,MULTIPLE 支持连选和多选
lb = tkinter.Listbox(win, selectmode=tkinter.MULTIPLE)

for i in ["green", "blue", "yellow", "white", "red", "black", "man","pig", "dog", "cat", "green", "blue","yellow", "white", "red", "black", "man", "pig", "dog", "cat"]:
    lb.insert(tkinter.END, i) 

sc = tkinter.Scrollbar(win)  # 滚动条
sc.pack(side=tkinter.RIGHT, fill=tkinter.Y)

lb.configure(yscrollcommand=sc.set)  # 关联配置
sc['command']=lb.yview  # 额外给属性赋值

lb.pack(side=tkinter.LEFT, fill=tkinter.BOTH)

效果图

Scale 控件

Scale供用户通过拖拽指示器改变变量的值,可以水平和竖直两个方向,默认竖直

scale = tkinter.Scale(win, from_=0, to=100, orient=tkinter.HORIZONTAL,tickinterval=10, length=300)

scale.set(10)  # 设置初始值
scale.pack()

def show():  # 点击按钮显示对应的数值
    print(scale.get())
tkinter.Button(win, text="显示", command=show).pack()

效果图

Spinbox 控件

v = tkinter.StringVar()

def update():
    print(v.get())  # 实时触发值的改变

# 数值范围控件  # increment 步长 默认为 1
sp = tkinter.Spinbox(win, from_=0, to=100, increment=5, textvariable=v, command=update)

# 注意 values 不要与 from_=0, to=100, increment=5 同时使用,不常用
# sp = tkinter.Spinbox(win, values=(0, 2, 4, 6, 8))

v.set(20)  
print(v.get())  

sp.pack()

效果图

Menu 控件 I

# 菜单条
menuBar = tkinter.Menu(win)
win.config(menu=menuBar)

# 创建一个菜单选项
menu1 = tkinter.Menu(menuBar, tearoff=True)

# 给菜单选项添加内容
for i in ["C", "C++", "Java", "Python", "PHP", "JS", "C#", "Mysql", "退出"]:
    if i == "退出":
        menu1.add_separator()  # 添加分割线
        menu1.add_command(label=i, command=win.quit)
    else:
        menu1.add_command(label=i)

menu2 = tkinter.Menu(menuBar, tearoff=False)
for i in ["white", "black", "red", "green", "blue", "yellow", "pink"]:
    menu2.add_command(label=i)

# 向菜单条中添加菜单选项
menuBar.add_cascade(label="Language", menu=menu1)
menuBar.add_cascade(label="Color", menu=menu2)

效果图

Menu 控件 II

# 鼠标右键显示菜单
menuBar = tkinter.Menu(win)

menu = tkinter.Menu(menuBar, tearoff=True)
for i in ["white", "black", "red", "green", "blue", "yellow", "pink"]:
    menu.add_command(label=i)

menuBar.add_cascade(label="Color", menu=menu)

def showMenu(event):
    menuBar.post(event.x_root, event.y_root)
win.bind("<Button-3>", showMenu)

最后一张效果图留给大家去实现,关于 Tkinter 的知识还有很多,之后 Mark 会将其总结出来放在公号后台,大家回复「Tkinter」即可获取,以上知识如有错误之处,望请指正。

原文发布于微信公众号 - Python梦工厂(AzMark950831)

原文发表时间:2018-06-29

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏十月梦想

vue入门基础详解之父子通讯

子组件需要监控一个事件,然后在实例中执行这个方法就行,函数参数可以传递data,然后在实例中执行改方法!

522
来自专栏Android干货

html基本标签(慕课网)

2855
来自专栏liulun

自己动手写客户端UI库——事件机制(设计思路大放送)

在上一篇文章中我们创建了一个Button控件,并把这个控件显示在界面上, 在这一篇文章中,我们将为这个控件增加一个事件和一个方法 一:怎么绑定事件的问题 ...

2009
来自专栏从零开始学 Web 前端

从零开始学 Web 之 Vue.js(六)Vue的组件

在这里我会从 Web 前端零基础开始,一步步学习 Web 相关的知识点,期间也会分享一些好玩的项目。现在就让我们一起进入 Web 前端学习的冒险之旅吧!

644
来自专栏练小习的专栏

当inline-block和text-indent遇到IE6,IE7

在实际应用中,考虑到seo,很多button,icon都要用到inline-block和text-indent来处理,例如: <a href="#" class...

1806
来自专栏超然的博客

react小结

在react中,父组件给子组件传递数据时,就是以上的方式,通过给子组件设置props,子组件获取props中的值便可完成数据传递。 

811
来自专栏从零开始学自动化测试

appium+python自动化26-模拟手势点击坐标(tap)

前言: 有时候定位元素的时候,你使出了十八班武艺还是定位不到,怎么办呢?(面试经常会问) 那就拿出绝招:点元素所在位置的坐标 一、 tap用法 1.tap是...

3644
来自专栏Google Dart

AngularDart Material Design 选择 顶

可以手动(在模板中)或通过SelectionOptions实例指定选项。 可以通过模板或通过检查选择模型将选项标记为已选择。

902
来自专栏大数据

Vue.js常见问题精选(一)

一、数据绑定不一定就是使用双大括号 “{{}}” 语法 我们都知道,Vue.js 最常见的数据绑定方式是使用“Mustache”语法(双大括号),Angular...

1816
来自专栏逸鹏说道

Markdown基础(内含:锚点使用,使用HTML,新页面跳转,目录生成)

如果要语法高亮就在```后面加小写语言名,eg:html,css,javascript,python,cs(csharp)等等

29611

扫码关注云+社区