8

使用下面的代码片段,我向 python 解释器添加了 tab 补全。

import readline
import rlcompleter
if 'libedit' in readline.__doc__:
    readline.parse_and_bind("bind ^I rl_complete")
else:
    readline.parse_and_bind("tab: complete")

但是,我遇到了一个奇怪的行为,在点击 TAB 后,解释器会给出这样的重复:

Python 2.7.3 (v2.7.3:70274d53c1dd, Apr  9 2012, 20:52:43)
[GCC 4.2.1 (Apple Inc. build 5666) (dot 3)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> d=dict()
>>> d.
Display all 108 possibilities? (y or n)
d.__class__(         d.__class__(         d.__class__(
d.__class__(         d.__cmp__(           d.__cmp__(
d.__contains__(      d.__contains__(      d.__delattr__(
d.__delattr__(       d.__delattr__(       d.__delitem__(
d.__delitem__(       d.__doc__            d.__doc__
d.__doc__            d.__eq__(            d.__eq__(
d.__format__(        d.__format__(        d.__format__(
d.__ge__(            d.__ge__(            d.__getattribute__(
d.__getattribute__(  d.__getattribute__(  d.__getitem__(
d.__getitem__(       d.__gt__(            d.__gt__(
d.__hash__           d.__hash__           d.__hash__
d.__init__(          d.__init__(          d.__init__(
d.__iter__(          d.__iter__(          d.__le__(
d.__le__(            d.__len__(           d.__len__(
d.__lt__(            d.__lt__(            d.__ne__(
d.__ne__(            d.__new__(           d.__new__(
d.__new__(           d.__reduce__(        d.__reduce__(
d.__reduce__(        d.__reduce_ex__(     d.__reduce_ex__(
d.__reduce_ex__(     d.__repr__(          d.__repr__(
d.__repr__(          d.__setattr__(       d.__setattr__(
d.__setattr__(       d.__setitem__(       d.__setitem__(
d.__sizeof__(        d.__sizeof__(        d.__sizeof__(
d.__str__(           d.__str__(           d.__str__(
d.__subclasshook__(  d.__subclasshook__(  d.__subclasshook__(
d.clear(             d.clear(             d.copy(
d.copy(              d.fromkeys(          d.fromkeys(
d.get(               d.get(               d.has_key(
d.has_key(           d.items(             d.items(
d.iteritems(         d.iteritems(         d.iterkeys(
d.iterkeys(          d.itervalues(        d.itervalues(
d.keys(              d.keys(              d.pop(
d.pop(               d.popitem(           d.popitem(
d.setdefault(        d.setdefault(        d.update(
d.update(            d.values(            d.values(
d.viewitems(         d.viewitems(         d.viewkeys(
d.viewkeys(          d.viewvalues(        d.viewvalues(

108种可能性!最少 2 个,最多 4 个重复项。

此外,

  • 如果我对可能性进行子类dict化,则可能性总数增加到 160(然后增加到 209、258)。
  • 如果我为 TAB 键入足够的字符来确定命令,它会这样做而不显示重复项。

任何指针或调试技巧表示赞赏。

4

1 回答 1

4

我通过添加自定义完成器解决了这个问题。它现在按预期工作。

import readline
import rlcompleter

c = rlcompleter.Completer()

def complete(text, state):
    buffer = readline.get_line_buffer()
    first = c.complete(buffer, 0)
    if state == 0:
        return first
    current = c.complete(buffer, state)
    if current != first:
        return current

readline.parse_and_bind('bind ^I rl_complete')
readline.set_completer(complete)
于 2013-03-31T18:18:50.253 回答