在基于 python/tkinter 的文本编辑器中实现文本自动完成

Posted

技术标签:

【中文标题】在基于 python/tkinter 的文本编辑器中实现文本自动完成【英文标题】:Implement text-autocompletion in python/tkinter based text editor 【发布时间】:2011-09-22 21:38:03 【问题描述】:

我想在下面代码框中提供的这个简单 Tkinter 文本编辑器的主文本窗口(不是 Tkinter.entry - 可以找到示例)中使用自动完成算法。我认为beeing的自动完成算法依赖于自动完成单词的列表,即代码示例[1]中提供的。

到目前为止,我已经找到了两个自动完成的代码示例,一个是用于 Tkinter 的使用输入框 [1] ,另一个是用于 IDLE [2] 的外部模块(由 Jerry King 编写)。

到目前为止,我通过将 [1] 代码的元素移动到文本编辑器来生成工作代码的所有尝试都失败了。请注意,我对 Tkinter 还很陌生,因此也在整个框架中苦苦挣扎

# taken from http://www.java2s.com/Code/Python/GUI-Tk/SimpleEditor.htm


from Tkinter import * 
from tkSimpleDialog import askstring
from tkFileDialog   import asksaveasfilename

from tkMessageBox import askokcancel          

class Quitter(Frame):                        
    def __init__(self, parent=None):          
        Frame.__init__(self, parent)
        self.pack()
        widget = Button(self, text='Quit', command=self.quit)
        widget.pack(expand=YES, fill=BOTH, side=LEFT)
    def quit(self):
        ans = askokcancel('Verify exit', "Really quit?")
        if ans: Frame.quit(self)


class ScrolledText(Frame):
    def __init__(self, parent=None, text='', file=None):
        Frame.__init__(self, parent)
        self.pack(expand=YES, fill=BOTH)               
        self.makewidgets()
        self.settext(text, file)
    def makewidgets(self):
        sbar = Scrollbar(self)
        text = Text(self, relief=SUNKEN)
        sbar.config(command=text.yview)                  
        text.config(yscrollcommand=sbar.set)           
        sbar.pack(side=RIGHT, fill=Y)                   
        text.pack(side=LEFT, expand=YES, fill=BOTH)     
        self.text = text
    def settext(self, text='', file=None):
        if file: 
            text = open(file, 'r').read()
        self.text.delete('1.0', END)                   
        self.text.insert('1.0', text)                  
        self.text.mark_set(INSERT, '1.0')              
        self.text.focus()                                
    def gettext(self):                               
        return self.text.get('1.0', END+'-1c')         



class SimpleEditor(ScrolledText):                        
    def __init__(self, parent=None, file=None): 
        frm = Frame(parent)
        frm.pack(fill=X)
        Button(frm, text='Open',  command=self.onSave).pack(side=LEFT)
        Button(frm, text='Save',  command=self.onSave).pack(side=LEFT)
        Button(frm, text='Cut',   command=self.onCut).pack(side=LEFT)
        Button(frm, text='Paste', command=self.onPaste).pack(side=LEFT)
        Button(frm, text='Find',  command=self.onFind).pack(side=LEFT)
        Quitter(frm).pack(side=LEFT)
        ScrolledText.__init__(self, parent, file=file) 
        self.text.config(font=('courier', 8, 'normal'))
    def Open(self):
        pass
    def onSave(self):
        filename = asksaveasfilename()
        if filename:
            alltext = self.gettext()                      
            open(filename, 'w').write(alltext)          
    def onCut(self):
        text = self.text.get(SEL_FIRST, SEL_LAST)        
        self.text.delete(SEL_FIRST, SEL_LAST)           
        self.clipboard_clear()              
        self.clipboard_append(text)
    def onPaste(self):                                    
        try:
            text = self.selection_get(selection='CLIPBOARD')
            self.text.insert(INSERT, text)
        except TclError:
            pass                                      
    def onFind(self):
        target = askstring('SimpleEditor', 'Search String?')
        if target:
            where = self.text.search(target, INSERT, END)  
            if where:                                    
                print where
                pastit = where + ('+%dc' % len(target))   
               #self.text.tag_remove(SEL, '1.0', END)     
                self.text.tag_add(SEL, where, pastit)     
                self.text.mark_set(INSERT, pastit)         
                self.text.see(INSERT)                    
                self.text.focus()



if __name__ == '__main__':
    try:
        SimpleEditor(file=sys.argv[1]).mainloop()   
    except IndexError:
        SimpleEditor().mainloop()                  

【问题讨论】:

【参考方案1】:

好吧,经过一番尝试,我想通了:

我使用了 IDLE 中的 AutoComplete 和 AutocompleteWindow 模块,并手动添加了所需的窗口参数。每次在键盘上敲击一组特定字符时都会调用 AutoComplete。

【讨论】:

拜托,你能把代码显示出来,让别人更清楚你做了什么吗?

以上是关于在基于 python/tkinter 的文本编辑器中实现文本自动完成的主要内容,如果未能解决你的问题,请参考以下文章

python tkinter Label

按钮点击后,Python tkinter在框架中显示文本

按下按钮后可以更改菜单栏文本吗? (Python,tkinter)

python tkinter Text

python Tkinter之Button

如何更改标签小部件中的文本大小,python tkinter [重复]