0

使用使用 jedi 的 atom 的 autocomplete-python 我发现multiprocessingpython3. 这是一个例子:

>>> import jedi
>>> source = '''
... import multiprocessing as mp
... mp.Pro'''
>>> script = jedi.Script(source, 3, len('mp.Pro'), 'example.py')
>>> script.completions()
[<Completion: process>]

模块实际上有process包,但它在模块范围内也有Process类:

>>> import multiprocessing as mp
>>> [n for n in mp.__all__ if n.endswith('rocess')]
['Process', 'current_process']

比较 python2 和 python3 的multiprocessing模块,我发现它们略有不同。现代版本导入默认上下文命名空间的命名空间:

globals().update((name, getattr(context._default_context, name))
             for name in context._default_context.__all__)
__all__ = context._default_context.__all__

不幸的是,我不知道如何解决这个问题或解决它。你有什么建议吗?

4

1 回答 1

1

Jedi 不理解写给 globals() 的内容。

这在http://jedi.readthedocs.io/en/latest/docs/features.html#unsupported-features中明确提到

很长一段时间以来,我什至没有考虑过实施这一点,现在我对此持开放态度。但可能会很久。(它不再是一个大的性能杀手。)

但是现在我认为你只需要忍受这个问题。

于 2016-11-09T19:31:20.997 回答