dano..
37
他们完全一样.事实上,分发Python模块的文档刚刚更新,建议使用python -m pip而不是pip可执行文件,因为它更容易分辨哪个版本的python将用于实际运行pip.
编辑:
这里有一些更具体的"证明",除了相信我的话和我链接的错误报告:)
如果您看一下pip可执行脚本,它只是这样做:
from pkg_resources import load_entry_point
load_entry_point('pip==1.5.4', 'console_scripts', 'pip')()
它正在调用load_entry_point,它返回一个函数,然后执行该函数.它正在使用的入口点被调用'console_scripts'.如果你查看pip我的Ubuntu机器上的/usr/lib/python2.7/dist-packages/pip-1.5.4.egg-info/entry_points.txt 的entry_points.txt文件,你会看到:
[console_scripts]
pip = pip:main
pip2.7 = pip:main
pip2 = pip:main
因此返回的入口点是模块中的main函数pip.
运行时python -m pip,您正在执行包__main__.py内的脚本pip.看起来像这样:
import sys
from .runner import run
if __name__ == '__main__':
exit = run()
if exit:
sys.exit(exit)
而runner.run功能如下:
def run():
base = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
## FIXME: this is kind of crude; if we could create a fake pip
## module, then exec into it and update pip.__path__ properly, we
## wouldn't have to update sys.path:
sys.path.insert(0, base)
import pip
return pip.main()
正如你所看到的,它也只是调用pip.main函数.所以这两个命令最终都调用了相同的main函数pip/__init__.py.
@ilciavo:小修正:`python -m pip`运行`pip/__ main __.py`模块,而不是`pip/__ init __.py`.这是一般规则:`python -m module`运行`module .__ main__`模块如果`module`是一个包(具有`__path__`属性),否则它运行`module`本身 - 两者都带有`__name __ ==" __main __"`. (3认同)