事实上,我完全困惑这是如何工作的。
我有通用的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
原文地址:https://www.jb51.cc/vim/389305.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。