Bor*_*zic 13 python deployment layout bootstrapping
背景:我有一个小的Python应用程序,让开发人员在我们公司发布软件的生活更轻松一些.我使用py2exe为Windows构建可执行文件.应用程序以及二进制文件都会检入Subversion.人们只需从SVN检出目录即可进行分发.该程序有大约6种不同的Python库依赖项(例如ElementTree,Mako)
情况:开发人员希望破解此工具的来源,然后在不必构建二进制文件的情况下运行它.目前这意味着他们需要一个python 2.6解释器(这很好),并且还使用easy_install在本地安装了6个库.
问题
轶事:这个过程越独立,就越容易重复.我让我的机器更换为新机器,并经历了不必要的过程,不得不对依赖项进行逆向工程,重新安装distutils,在线搜索库并让它们安装(参见上面的公司互联网限制).
"我不喜欢这样一个事实,即开发人员(或者我从一台干净的新机器开始)必须跳过必须在本地安装库才能开始之前的数据库"
为什么?
什么 - 具体 - 这是错的?
你这样做是为了创建项目.您的项目非常受欢迎,其他人也希望这样做.
我没有看到问题.请根据您需要解决的具体问题更新您的问题.不喜欢分发开源的方式不是问题 - 这是开源工作的方式.
编辑."围墙花园"并不重要.
选择1.你可以,BTW,建立一个"安装程序",为他们运行easy_install 6次.
选择2.您可以保存easy_install将使用的所有安装程序工具包.然后你可以提供一个解压缩的脚本和一个python setup.py install用于所有六个的脚本.
选择3.您可以提供您的压缩版本site-packages.在安装Python之后,他们将您的site-packages目录解压缩到`C:\ Python2.5\lib\site-packages``.
选择4.您可以为Python环境构建自己的MSI安装程序工具包.
选择5.您可以托管自己的类似pypi的服务器并提供easy_install,以便首先检查您的服务器.
我有时会使用下面描述的方法,因为@Boris声明的原因完全相同:我希望使用某些代码就像a)svn checkout/update - b)go一样简单.
但是为了记录:
无论如何,我使用的方法取决于修改sys.path,并且这样工作:
project/
*.py
scriptcustomize.py
file.pth
thirdparty/
eggs/
mako-vNNN.egg
... .egg
code/
elementtree\
*.py
...
from scriptcustomize import apply_pth_files apply_pth_files(__file__)
import os
from glob import glob
import fileinput
import sys
def apply_pth_files(scriptfilename, at_beginning=False):
"""At the top of your script:
from scriptcustomize import apply_pth_files
apply_pth_files(__file__)
"""
directory = os.path.dirname(scriptfilename)
files = glob(os.path.join(directory, '*.pth'))
if not files:
return
for line in fileinput.input(files):
line = line.strip()
if line and line[0] != '#':
path = os.path.join(directory, line)
if at_beginning:
sys.path.insert(0, path)
else:
sys.path.append(path)
# contents of *.pth file thirdparty/code thirdparty/eggs/mako-vNNN.egg