如何在Tkinter文本搜索方法中使用正则表达式?

时间:2014-01-05 19:56:53

标签: python tkinter highlight highlighting

我想在方括号内找到一个突出显示的区域。这些方括号可能包含任何文字:[A hello world] [B this is a tree] [A tkinter documentation is bad]

我想突出括号中带有“A”字符的单词,如下所示: enter image description here

要获取起始索引和匹配字符的数量,我尝试了这个:

countVar = StringVar()
reg_area = re.compile(r'\[A.*\]')
index = text.search('1.0', reg_area, stopindex=END, count=countVar, regexp = True)

这不起作用,我收到了。

TclError: bad text index "<_sre.SRE_Pattern object at 0x3856d78>"

如何查找所有出现并正确突出显示?

1 个答案:

答案 0 :(得分:2)

你有两个问题。首先,您将位置参数置于错误的顺序。第一个位置参数应该是模式,第二个位置参数被视为起始索引。由于您的第二个参数是SRE_Pattern的实例,因此您会收到错误的文本索引错误。

您需要更改参数的顺序,以便您的第一个参数是模式。接下来的两个参数应该是开始和结束索引。

其次,当您将regexp设置为True时,您仍必须将该模式作为字符串传递。文本小部件将该字符串解释为正则表达式。您无法传入已编译的正则表达式。

这是一个应该有效的例子:

index = text.search(r'\[A.*\]', "1.0", END, count=countVar, regexp=True)

FWIW,问题this answerTkinter text highlighting in python给出了一个子类化Text类的示例,以添加名为highlight_pattern的方法。