如何绑定tkinter中的退格键以删除多个字符?

前端之家收集整理的这篇文章主要介绍了如何绑定tkinter中的退格键以删除多个字符?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想创建绑定,让我按Tab键插入预定义数量的空格,然后按退格键删除那么多空格,基于变量.

用户按下退格键时,如何删除预定数量的空格?我不知道如何删除多个字符,当我试图解决这个问题时,绑定会删除错误的字符数.

解决方法

这个问题分为两部分.第一部分与如何相关
一次删除多个字符.第二部分是如何在绑定到退格键的绑定中使用它

删除多个字符

文本小部件的delete方法有两个索引,并将删除
这些索引之间的字符. Tkinter文本索引可以是相对的
通过将修饰符应用于索引.例如,参考四个
插入点之前的字符可以使用索引“insert”加上修饰符“-4 chars”.

例:

  1. self.text.delete("insert -4 chars","insert")

因为这些索引是普通字符串,所以如果要使用变量,可以使用字符串格式.

例:

  1. tabWidth = 4
  2. self.text.delete("insert -%d chars" % tabWidth,"insert")

使用带绑定的功能

要在用户按退格键时运行功能,您可以绑定
< BackSpace>的函数事件.此功能将被传递
一个代表事件的参数.

例如:

  1. self.text.bind("<BackSpace>",self.do_backspace)
  2. ...
  3. def do_backspace(self,event):
  4. ...

对标准键进行自定义绑定的一个重要部分是知道默认情况下绑定不会替换默认行为.例如,如果您的绑定删除了一个字符然后返回,则会删除两个字符,因为您的绑定将删除一个,默认绑定将删除一个.

覆盖此行为的方法是返回字符串“break”.因为您的自定义绑定发生在默认绑定之前,所以默认绑定将看到您返回“break”并且什么都不做.这使得在保持默认行为的同时覆盖默认行为或执行其他工作非常简单.

总而言之,如果它们是四个连续的空格,则可以定义一个删除前四个字符的函数,如果不是,则执行默认行为:

  1. def do_backspace(self,event):
  2. # get prevIoUs <tabWidth> characters; if they are all spaces,remove them
  3.  
  4. prevIoUs = self.text.get("insert -%d chars" % self.tabWidth,"insert")
  5. if prevIoUs == " " * self.tabWidth:
  6. self.text.delete("insert-%d chars" % self.tabWidth,"insert")
  7.  
  8. # return "break" so that the default behavior doesn't happen
  9. return "break"
  10.  
  11. # if we get to here,we'll just return. That allows the default
  12. # behavior to run

把它们放在一起

这是一个完整的工作示例,当您插入四个空格时
按Tab键,按退格键时删除四个空格:

  1. import tkinter as tk
  2.  
  3. def do_tab(event):
  4. text.insert("insert"," " * tabWidth)
  5. # return "break" so that the default behavior doesn't happen
  6. return "break"
  7.  
  8. def do_backspace(event):
  9. # get prevIoUs <tabWidth> characters; if they are all spaces,remove them
  10. prevIoUs = text.get("insert -%d chars" % tabWidth,"insert")
  11. if prevIoUs == " " * tabWidth:
  12. text.delete("insert-%d chars" % tabWidth,"insert")
  13. # return "break" so that the default behavior doesn't happen
  14. return "break"
  15.  
  16. # if we get to here,we'll just return. That allows the default
  17. # behavior to run
  18.  
  19. root = tk.Tk()
  20. tabWidth = 4
  21.  
  22. text = tk.Text(root)
  23. text.pack(fill="both",expand=True)
  24.  
  25. text.bind("<Tab>",do_tab)
  26. text.bind("<BackSpace>",do_backspace)
  27.  
  28. root.mainloop()

猜你在找的Python相关文章