基于Python3的tkinter Text文本框加滚动条显示信息

        用tkinter进行界面程序开发中,经常需要将信息展示到界面上,给用户及时的反馈和想要看到的结果。Text控件允许用户以不同的样式、属性来显示和编辑文本,它可以包含纯文本或者格式化文本,同时支持嵌入图片、显示超链接以及带有 CSS 格式的 HTML 等。

一:整体界面

 里面用到的组件:

1,Radiobutton控件:,单选按钮,

2,Text控件:文本框,显示信息

3,Scrollbar控件:滚动条

4,Button控件:按钮

二: 整体代码框架

def main(self):
        lb = Label(root, text='可视化工具', \
                #bg='#d3fbfb', \
                fg='olive', \
                font=('华文新魏', 12), \
                width=50, \
                height=2, \
                relief=FLAT)
        lb.place(relx=0.25, rely=0.01)

        var = IntVar()
        var.set(2)
        rd1 = Radiobutton(root, text="func 1", fg='red',variable=var, value=0, command=lambda: self.showResult(var.get()))
        rd1.place(relx = 0.23,rely = 0.2)
        rd2 = Radiobutton(root, text="func 2", fg='blue',variable=var, value=1,command=lambda: self.showResult(var.get()))
        rd2.place(relx = 0.4,rely = 0.2)
        rd3 = Radiobutton(root, text="func 3", fg='green',variable=var, value=2,command=lambda: self.showResult(var.get()))
        rd3.place(relx = 0.57,rely = 0.2)

        rd4 = Radiobutton(root, text="func 4", fg='DeepPink',variable=var, value=3, command=lambda: self.showResult(var.get()))
        rd4.place(relx = 0.23,rely = 0.25)
        rd5 = Radiobutton(root, text="func 5", fg='SlateBlue',variable=var, value=4,command=lambda: self.showResult(var.get()))
        rd5.place(relx = 0.4,rely = 0.25)
        rd6 = Radiobutton(root, text="func 6", fg='Brown',variable=var, value=5,command=lambda: self.showResult(var.get()))
        rd6.place(relx = 0.57,rely = 0.25)

        startButton = Button(root, text='Start',font=('华文新魏', 20),  activebackground = "green", command=lambda: self.startFunc(var.get()))
        startButton.place(relx=0.35, rely=0.89, relwidth=0.3, relheight=0.1)

点击start按钮在Text控件中显示信息,Text控件绑定滚动条

def startFunc(self,selectFunc):
        self.collectInfo = [1,2,3,4,5,6]
        if not self.collectInfo:
            return
        if self.startButtonFirst == 0:
            self.validInfo = Text(root, width=100, height=19)#, undo=True, autoseparators=False
            self.validInfo.place(relx=0.01, rely=0.32)
            # 放到窗口的右侧, 填充Y竖直方向
            self.scroll = Scrollbar()
            self.scroll.pack(side=RIGHT,fill=Y)
            # 两个控件关联
            self.scroll.config(command=self.validInfo.yview)
            self.validInfo.config(yscrollcommand=self.scroll.set)
        self.validInfo.delete('1.0','end')
        if selectFunc == 0:
            self.validInfo.insert(INSERT, )
        elif selectFunc == 1:
            self.validInfo.insert(INSERT, self.collectInfo[1])
        elif selectFunc == 2:
            self.validInfo.insert(INSERT, self.collectInfo[2])
        elif selectFunc == 3:
            self.validInfo.insert(INSERT, self.collectInfo[3])
        elif selectFunc == 4:
            self.validInfo.insert(INSERT, self.collectInfo[4])
        elif selectFunc == 5:
            self.validInfo.insert(INSERT, self.collectInfo[5])
        self.startButtonFirst = 1

点击单选按钮显示信息

def showResult(self,selectFunc):
        if self.startButtonFirst == 0:
            return
        self.validInfo.delete('1.0','end')
        if selectFunc == 0:
            self.validInfo.insert(INSERT, self.collectInfo[0])
        elif selectFunc == 1:
            self.validInfo.insert(INSERT, self.collectInfo[1])
        elif selectFunc == 2:
            self.validInfo.insert(INSERT, self.collectInfo[2])
        elif selectFunc == 3:
            self.validInfo.insert(INSERT, self.collectInfo[3])
        elif selectFunc == 4:
            self.validInfo.insert(INSERT, self.collectInfo[4])
        elif selectFunc == 5:
            self.validInfo.insert(INSERT, self.collectInfo[5])

三:Text控件

1,基本属性

属性说明
autoseparators默认为 True,表示执行撤销操作时是否自动插入一个“分隔符”(其作用是用于分隔操作记录)
exportselection默认值为 True,表示被选中的文本是否可以被复制到剪切板,若是 False 则表示不允许。
insertbackground设置插入光标的颜色,默认为 BLACK
insertborderwidth设置插入光标的边框宽度,默认值为 0
insertofftime该选项控制光标的闪烁频频率(灭的状态)
insertontime该选项控制光标的闪烁频频率(亮的状态)
selectbackground指定被选中文本的背景颜色,默认由系统决定
selectborderwidth指定被选中文本的背景颜色,默认值是0
selectforeground指定被选中文本的字体颜色,默认值由系统指定
setgrid默认值是 False,指定一个布尔类型的值,确定是否启用网格控制
spacing1指定 Text 控件文本块中每一行与上方的空白间隔,注意忽略自动换行,且默认值为 0。
spacing2指定 Text 控件文本块中自动换行的各行间的空白间隔,忽略换行符,默认值为0
spacing3指定 Text 组件文本中每一行与下方的空白间隔,忽略自动换行,默认值是 0
tabs定制 Tag 所描述的文本块中 Tab 按键的功能,默认被定义为 8 个字符宽度,比如 tabs=('1c', '2c', '8c') 表示前 3 个 Tab 宽度分别为 1厘米,2厘米,8厘米。
undo该参数默认为 False,表示关闭 Text 控件的“撤销”功能,若为 True 则表示开启
wrap该参数用来设置当一行文本的长度超过 width 选项设置的宽度时,是否自动换行,参数值 none(不自动换行)、char(按字符自动换行)、word(按单词自动换行)
xscrollcommand该参数与 Scrollbar 相关联,表示沿水平方向上下滑动
yscrollcommand该参数与 Scrollbar 相关联,表示沿垂直方向左右滑动

2,基本方法

方法说明
bbox(index)返回指定索引的字符的边界框,返回值是一个 4 元组,格式为(x,y,width,height)
edit_modified()该方法用于查询和设置 modified 标志(该标标志用于追踪 Text 组件的内容是否发生变化)
edit_redo()“恢复”上一次的“撤销”操作,如果设置 undo 选项为 False,则该方法无效。
edit_separator()插入一个“分隔符”到存放操作记录的栈中,用于表示已经完成一次完整的操作,如果设置 undo 选项为 False,则该方法无效。
get(index1, index2)返回特定位置的字符,或者一个范围内的文字。
image_cget(index, option)返回 index 参数指定的嵌入 image 对象的 option 选项的值,如果给定的位置没有嵌入 image 对象,则抛出 TclError 异常
image_create()在 index 参数指定的位置嵌入一个 image 对象,该 image 对象必须是 Tkinter 的 PhotoImage 或 BitmapImage 实例。
insert(index, text)在 index 参数指定的位置插入字符串,第一个参数也可以设置为 INSERT,表示在光标处插入,END 表示在末尾处插入。
delete(startindex [, endindex])删除特定位置的字符,或者一个范围内的文字。
see(index)如果指定索引位置的文字是可见的,则返回 True,否则返回 False。

四:tkinter支持的颜色汇总

在tkinter中有很多颜色的设置,此处汇总一下,不用四处找了

  1. '''#FFB6C1 LightPink 浅粉红

  2. #FFC0CB Pink 粉红

  3. #DC143C Crimson 深红/猩红

  4. #FFF0F5 LavenderBlush 淡紫红

  5. #DB7093 PaleVioletRed 弱紫罗兰红

  6. #FF69B4 HotPink 热情的粉红

  7. #FF1493 DeepPink 深粉红

  8. #C71585 MediumVioletRed 中紫罗兰红

  9. #DA70D6 Orchid 暗紫色/兰花紫

  10. #D8BFD8 Thistle 蓟色

  11. #DDA0DD Plum 洋李色/李子紫

  12. #EE82EE Violet 紫罗兰

  13. #FF00FF Magenta 洋红/玫瑰红

  14. #FF00FF Fuchsia 紫红/灯笼海棠

  15. #8B008B DarkMagenta 深洋红

  16. #800080 Purple 紫色

  17. #BA55D3 MediumOrchid 中兰花紫

  18. #9400D3 DarkViolet 暗紫罗兰

  19. #9932CC DarkOrchid 暗兰花紫

  20. #4B0082 Indigo 靛青/紫兰色

  21. #8A2BE2 BlueViolet 蓝紫罗兰

  22. #9370DB MediumPurple 中紫色

  23. #7B68EE MediumSlateBlue 中暗蓝色/中板岩蓝

  24. #6A5ACD SlateBlue 石蓝色/板岩蓝

  25. #483D8B DarkSlateBlue 暗灰蓝色/暗板岩蓝

  26. #E6E6FA Lavender 淡紫色/熏衣草淡紫

  27. #F8F8FF GhostWhite 幽灵白

  28. #0000FF Blue 纯蓝

  29. #0000CD MediumBlue 中蓝色

  30. #191970 MidnightBlue 午夜蓝

  31. #00008B DarkBlue 暗蓝色

  32. #000080 Navy 海军蓝

  33. #4169E1 RoyalBlue 皇家蓝/宝蓝

  34. #6495ED CornflowerBlue 矢车菊蓝

  35. #B0C4DE LightSteelBlue 亮钢蓝

  36. #778899 LightSlateGray 亮蓝灰/亮石板灰

  37. #708090 SlateGray 灰石色/石板灰

  38. #1E90FF DodgerBlue 闪兰色/道奇蓝

  39. #F0F8FF AliceBlue 爱丽丝蓝

  40. #4682B4 SteelBlue 钢蓝/铁青

  41. #87CEFA LightSkyBlue 亮天蓝色

  42. #87CEEB SkyBlue 天蓝色

  43. #00BFFF DeepSkyBlue 深天蓝

  44. #ADD8E6 LightBlue 亮蓝

  45. #B0E0E6 PowderBlue 粉蓝色/火药青

  46. #5F9EA0 CadetBlue 军兰色/军服蓝

  47. #F0FFFF Azure 蔚蓝色

  48. #E0FFFF LightCyan 淡青色

  49. #AFEEEE PaleTurquoise 弱绿宝石

  50. #00FFFF Cyan 青色

  51. #00FFFF Aqua 浅绿色/水色

  52. #00CED1 DarkTurquoise 暗绿宝石

  53. #2F4F4F DarkSlateGray 暗瓦灰色/暗石板灰

  54. #008B8B DarkCyan 暗青色

  55. #008080 Teal 水鸭色

  56. #48D1CC MediumTurquoise 中绿宝石

  57. #20B2AA LightSeaGreen 浅海洋绿

  58. #40E0D0 Turquoise 绿宝石

  59. #7FFFD4 Aquamarine 宝石碧绿

  60. #66CDAA MediumAquamarine 中宝石碧绿

  61. #00FA9A MediumSpringGreen 中春绿色

  62. #F5FFFA MintCream 薄荷奶油

  63. #00FF7F SpringGreen 春绿色

  64. #3CB371 MediumSeaGreen 中海洋绿

  65. #2E8B57 SeaGreen 海洋绿

  66. #F0FFF0 Honeydew 蜜色/蜜瓜色

  67. #90EE90 LightGreen 淡绿色

  68. #98FB98 PaleGreen 弱绿色

  69. #8FBC8F DarkSeaGreen 暗海洋绿

  70. #32CD32 LimeGreen 闪光深绿

  71. #00FF00 Lime 闪光绿

  72. #228B22 ForestGreen 森林绿

  73. #008000 Green 纯绿

  74. #006400 DarkGreen 暗绿色

  75. #7FFF00 Chartreuse 黄绿色/查特酒绿

  76. #7CFC00 LawnGreen 草绿色/草坪绿

  77. #ADFF2F GreenYellow 绿黄色

  78. #556B2F DarkOliveGreen 暗橄榄绿

  79. #9ACD32 YellowGreen 黄绿色

  80. #6B8E23 OliveDrab 橄榄褐色

  81. #F5F5DC Beige 米色/灰棕色

  82. #FAFAD2 LightGoldenrodYellow 亮菊黄

  83. #FFFFF0 Ivory 象牙色

  84. #FFFFE0 LightYellow 浅黄色

  85. #FFFF00 Yellow 纯黄

  86. #808000 Olive 橄榄

  87. #BDB76B DarkKhaki 暗黄褐色/深卡叽布

  88. #FFFACD LemonChiffon 柠檬绸

  89. #EEE8AA PaleGoldenrod 灰菊黄/苍麒麟色

  90. #F0E68C Khaki 黄褐色/卡叽布

  91. #FFD700 Gold 金色

  92. #FFF8DC Cornsilk 玉米丝色

  93. #DAA520 Goldenrod 金菊黄

  94. #B8860B DarkGoldenrod 暗金菊黄

  95. #FFFAF0 FloralWhite 花的白色

  96. #FDF5E6 OldLace 老花色/旧蕾丝

  97. #F5DEB3 Wheat 浅黄色/小麦色

  98. #FFE4B5 Moccasin 鹿皮色/鹿皮靴

  99. #FFA500 Orange 橙色

  100. #FFEFD5 PapayaWhip 番木色/番木瓜

  101. #FFEBCD BlanchedAlmond 白杏色

  102. #FFDEAD NavajoWhite 纳瓦白/土著白

  103. #FAEBD7 AntiqueWhite 古董白

  104. #D2B48C Tan 茶色

  105. #DEB887 BurlyWood 硬木色

  106. #FFE4C4 Bisque 陶坯黄

  107. #FF8C00 DarkOrange 深橙色

  108. #FAF0E6 Linen 亚麻布

  109. #CD853F Peru 秘鲁色

  110. #FFDAB9 PeachPuff 桃肉色

  111. #F4A460 SandyBrown 沙棕色

  112. #D2691E Chocolate 巧克力色

  113. #8B4513 SaddleBrown 重褐色/马鞍棕色

  114. #FFF5EE Seashell 海贝壳

  115. #A0522D Sienna 黄土赭色

  116. #FFA07A LightSalmon 浅鲑鱼肉色

  117. #FF7F50 Coral 珊瑚

  118. #FF4500 OrangeRed 橙红色

  119. #E9967A DarkSalmon 深鲜肉/鲑鱼色

  120. #FF6347 Tomato 番茄红

  121. #FFE4E1 MistyRose 浅玫瑰色/薄雾玫瑰

  122. #FA8072 Salmon 鲜肉/鲑鱼色

  123. #FFFAFA Snow 雪白色

  124. #F08080 LightCoral 淡珊瑚色

  125. #BC8F8F RosyBrown 玫瑰棕色

  126. #CD5C5C IndianRed 印度红

  127. #FF0000 Red 纯红

  128. #A52A2A Brown 棕色

  129. #B22222 FireBrick 火砖色/耐火砖

  130. #8B0000 DarkRed 深红色

  131. #800000 Maroon 栗色

  132. #FFFFFF White 纯白

  133. #F5F5F5 WhiteSmoke 白烟

  134. #DCDCDC Gainsboro 淡灰色

  135. #D3D3D3 LightGrey 浅灰色

  136. #C0C0C0 Silver 银灰色

  137. #A9A9A9 DarkGray 深灰色

  138. #808080 Gray 灰色

  139. #696969 DimGray 暗淡灰

  140. #000000 Black 纯黑'''

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/20158.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【纳什博弈、ADMM】基于纳什博弈和交替方向乘子法的多微网主体能源共享研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

Spring 注解之@RestController与@Controller的区别

目录 1:介绍 2:区别 3:总体来说 4:社区地址 1:介绍 RestController 和 Controller 是 Spring MVC 中常用的两个注解,它们都可以用于定义一个控制器类。 2:区别 返回值类型不同:…

使用插件快速生成代码

使用插件快速生成代码 咋们常说,授人以鱼不如授人以渔,在这里给大家提供一些技巧性的东西,方便一些新手同学可以快速上手,同时,也提高我们的开发兴趣与开发热情! 主要讲什么呢,我们来学一学如何…

让AI来告诉你什么叫幽灵堵车

使用环境参考 CocosCreator v3.7.2 ChatGPT 正文 什么是幽灵堵车 堵车,大家都不陌生! 堵车时我就思维发散,用 CocosCreator 模拟下堵车应该挺好玩,网上总说高速上最前面如果有个龟速的车,后面能堵车堵个两三公里。…

文本三剑客之sed

sed 一.概念 sed是一种流编辑器,流编辑器会在编辑器处理数据之前基于预先提供的一组规则来编辑数据流。 sed编辑器可以根据命令来处理数据流中的数据,这些命令要么从命令行中输入,要么存储一个命令文本文件中。二.工作流程 读取: sed从输入…

【论文阅读】MINOTAUR: Multi-task Video Grounding From Multimodal Queries

背景动机 细粒度的视频理解已经成为增强现实(AR)和机器人应用开发的关键能力。为了达到这种级别的视频理解,智能体(例如虚拟助手)必须具备识别和推理视频中捕获的事件和对象的能力,处理一系列视觉任务,如活动检测、对象检索和(空间)时间基础…

ChatGPT教程(终极版)

纯小白关于ChatGPT入门,你看我这篇文章就够了。 如果你已经用上了ChatGPT,更要恭喜你挖到宝藏,后面的高级技巧一定能让你有收获。 文章包含以下内容: 一、ChatGPT是啥?有什么用; 二、ChatGPT如何注册&…

jetson nx 用windows远程连接

VNC Viewer远程连接 一、jetson nx配置vnc 1、安装客户端 sudo apt-get install xrdp vnc4server xbase-clients2、进入nano/nx桌面,打开“Setting–>Desktop sharing”,没反应,据说是bug,我试过nano和nx都一样。首先输入下…

【c语言】组件化打包—静态库

创作不易&#xff0c;本篇文章如果帮助到了你&#xff0c;还请点赞 关注支持一下♡>&#x16966;<)!! 主页专栏有更多知识&#xff0c;如有疑问欢迎大家指正讨论&#xff0c;共同进步&#xff01; &#x1f525;c语言系列专栏&#xff1a;c语言之路重点知识整合 &#x…

IoT -- 解读物联网四层架构

本文以物联网四层架构为基础&#xff0c;从物联网产品设计的角度来解读每层架构的功能以及主要内容&#xff0c;旨在为物联网产品设计以及实现思路感兴趣的物联网产品或研发人员有些帮助。 通过互联网&#xff0c;人和人之间可以传递和交流信息。物联网&#xff0c;IoT&#x…

网络安全:Hydra 端口爆破工具.(九头蛇)

网络安全&#xff1a;Hydra 端口爆破工具.&#xff08;九头蛇&#xff09; Hydra 也叫九头蛇&#xff0c;是一款开源的暴力PJ工具&#xff0c;集成在kali当中。可以对多种服务的账号和密码进行爆破&#xff0c;包括 Web 登录、数据库、SSH、FTP 等服务. 目录&#xff1a; 网络…

调用api实现ChatGPT接口余额查询

在ChatGPT官网可以查询接口使用额度&#xff0c;但是官方并没有提供相应的API给开发者调用。我们可以通过破解的方式找到它的API。方法如下&#xff1a; 1. 使用Chrome浏览器打开https://platform.openai.com/account/usage 2. 打开开发者工具&#xff0c;然后刷新网页&#xf…

我让gpt写了一段正则表达式代码,可是运行报错,可以帮忙看看哪里出了问题?...

点击上方“Python爬虫与数据挖掘”&#xff0c;进行关注 回复“书籍”即可获赠Python从入门到进阶共10本电子书 今 日 鸡 汤 忽闻海上有仙山&#xff0c;山在虚无缥缈间。 大家好&#xff0c;我是皮皮。 一、前言 前几天在Python最强王者群【HZL】问了一个Python正则表达式的问…

ES6知识点

目录 1、let、cons、var的区别 2、const对象的属性可以修改吗 3、如果new一个箭头函数会怎么样 4、箭头函数和普通函数的区别&#xff1a; 5、扩展运算符的作用及使用场景 1、let、cons、var的区别 1️⃣&#xff1a;块级作用域&#xff1a;块作用域由{}包括&#xff0c;le…

ERM LABS 与 The Sandbox 战略合作,将真人密室逃脱游戏引进元宇宙

将现实生活中的体验带入一个全新的维度&#xff01;ERM LABS 专注于将现实生活中的娱乐及冒险体验以游戏独特架构设计扩展到元宇宙裡。与 The Sandbox 合作&#xff0c;该项目旨在为全球合作的真人密室逃脱场所提供无限开放形的线上虚拟世界&#xff0c;让玩家尽情享受考验智商…

09——svg中path的使用

一、path 是 svg 中最强大的图形 用于定义一个 路径所有命令均允许小写字母。大写 表示绝对定位&#xff0c;小写 表示 相对定位 &#xff08;相对于上一个结束的坐标&#xff09;d 属性中包含所有路径的点&#xff0c;可根据命令缩写 自由组合 命令 名称 …

最全的分布式事务详情,它来啰~

我们首先得理解什么是分布式事务呢&#xff1f;分布式事务是指在分布式系统中&#xff0c;涉及多个计算机或服务器的操作序列&#xff0c;这些操作需要满足一致性和可靠性的要求。每个操作要么全部成功执行&#xff0c;要么全部回滚&#xff0c;以保持数据的一致性和完整性。 …

假期出行小程序+chatgpt旅游攻略

马上五一了,如果想出去旅游,需要提取规划好路线图,我们可以借助chatgpt的路线规划功能帮我们生成一份攻略,按照攻略我们就可以愉快的出去玩耍了。 本文结合chatgpt,利用低代码工具帮我们制作一份旅行导览小程序,可以按照行程方便的出行。 1 制定攻略 我们在聊天窗口输…

从小白到黑客高手:一份全面详细的学习路线指南

前言 黑客从入门到精通需要经过深入的学习和实践&#xff0c;这是一个需要长时间投入和大量精力的过程。在这份学习路线中&#xff0c;我将为你介绍黑客学习的基本知识和技能&#xff0c;帮助你逐步掌握黑客技能。 黑客 一、入门阶段 1.了解计算机基础知识 学习计算机基础知…

thinkPhP6.0安装教程图解--PHP框架安装

ThinkPhP 6.0 安装 1.环境检查 首先&#xff0c;thinkphp6.0&#xff0c;要求php的环境是7.2.5及以上的&#xff0c;所以先检查自己的php环境是否符合要求。 在cmd命令窗口中输入php -v 或者没有配置环境变量的话&#xff0c;可以在php编辑器中输出php_info()或则PHP_VERSIO…