事实上,我完全困惑这是如何工作的。
我有通用的gvim 7.3,在windows 7(使用python / dyn)
我使用SuperTab插件,其中许多,其中一些
是python特定的,在vimrc中有以下设置:
au FileType python set omnifunc=pythoncomplete#Complete let g:SuperTabDefaultCompletionType = "context" let g:SuperTabContextDefaultCompletionType = "<c-n>"
我没有设置PYTHONPATH环境变量。
完成对系统模块工作正常。
起初,我认为它不是在非系统的工作
代码,但事实并非如此。
发生的事情最好显示在以下代码:
import numpy.random # if this line is commented completion in last line works class C(object): def __init__(self,x_): self.x=x_ def getX(self): return self.x def pr(self): print 'ok' a=C(10) # nothing changes if I put C() instead,even though it would be wrong a. # here is completion in question
问题是,如果导入行被注释,完成工作(a。< tab>建议getX和pr)。但它有进口numpy.random,完成刹车下来。
注意:这个导入在我运行代码时正常工作。
Python完成的先决条件是什么?
发生了什么,我应该做什么来完成工作的Python。
由于我是(相对)Vim的新,任何建议是赞赏。
编辑:
似乎问题是在导入中使用a.b形式。如果我从numpy导入随机,一切都确定。如果这是相当容易修复,我想得到a.b从工作也。但现在我知道如何去绕过这不是那么重要。
有没有更多不寻常的问题,像这样,使我知道未来发生了什么?
尝试使用Jedi:https://github.com/davidhalter/jedi-vim
它最初是一个改进的pythoncomplete,但现在是强大得多!
它适用于复杂的代码:
并有其他功能:
有一个所有可能的功能的列表:
>内置函数/类支持>复杂模块/函数/类结构>忽略语法和缩进错误>多个收益/收益率>元组赋值/数组索引/字典索引> exceptions / with-statement> * args / ** kwargs>装饰> descriptors – > property / staticmethod / classmethod>闭包>生成器(yield语句)/迭代器>支持一些魔术方法:__call__,__iter__,__next__,__get__,__getitem__,__init__>支持list.append,set.add,list.extend等。>(嵌套)列表推导/三元表达式>相对进口> getattr()/ __getattr__ / __getattribute__>函数注释(py3k特性,现在被忽略,但正在被解析。我不知道该怎么办。)>类装饰器(py3k特性,也被忽略,直到我找到一个使用case,这不工作与Jedi)>简单/通常的sys.path修改> isinstance检查是否/ while / assert