470,619 Members | 1,587 Online
Bytes | Developer Community
New Post

Home Posts Topics Members FAQ

Post your question to a community of 470,619 developers. It's quick & easy.

Is there a way to "link" a python program from several files?

IOW, is there a "linker" for python? I've written a program comprised of about
five .py files. I'd like to find a way to combine them into a single
executable. Obviously, I could hand-edit them into a single .py file, but
I'm looking for a way to keep them as seperate files for development but
distribute the result as a single file.

If this were C, I'd compile and link them and distribute the resulting
executable. I'm trying to do that, but for Python.

TIA,

--
-Ed Falk, fa**@despams.r.us.com
http://thespamdiaries.blogspot.com/
Feb 16 '08 #1
8 1409
Edward A. Falk schrieb:
IOW, is there a "linker" for python? I've written a program comprised of about
five .py files. I'd like to find a way to combine them into a single
executable. Obviously, I could hand-edit them into a single .py file, but
I'm looking for a way to keep them as seperate files for development but
distribute the result as a single file.

If this were C, I'd compile and link them and distribute the resulting
executable. I'm trying to do that, but for Python.
Depending on the OS, there are several options. Ranging from
distributing an .egg (setuptools) over py2exe for windows to py2app on
OSX - and some more, e.g. cx_freeze.

Google for one of the above.

Diez
Feb 16 '08 #2
Diez B. Roggisch wrote:
Edward A. Falk schrieb:
IOW, is there a "linker" for python? I've written a
program comprised of about five .py files. I'd like to
find a way to combine them into a single executable.
Obviously, I could hand-edit them into a single
.py file, but I'm looking for a way to keep them as
seperate files for development but distribute the
result as a single file.
Depending on the OS, there are several options. Ranging from
distributing an .egg (setuptools) over py2exe for windows to
py2app on OSX - and some more, e.g. cx_freeze.
I would be interested in a program that can combine multiple modules
into a single module, which removes all the inter-package imports and
fixes other inter-module references, like Haskell All-in-One does for
Haskell: http://www.cs.utah.edu/~hal/HAllInOne/index.html

- Brian

Feb 16 '08 #3
"Brian Smith" <br***@briansmith.orgwrites:
So does Haskell. Haskell All-In-One handles that by renaming every
top-level artifact.
That can't be done reliably in python because namespaces are dynamic.
If it is possible to run an egg as a CGI (without modifying the web
server configuration file), then that would work as well.
This would be an interesting enhancement.
Feb 16 '08 #4
On Feb 16, 7:53 pm, f...@green.rahul.net (Edward A. Falk) wrote:
IOW, is there a "linker" for python? I've written a program comprised of about
five .py files. I'd like to find a way to combine them into a single
executable.
I wrote a small wiki page to sum-up my findings about such typical
problem:

http://www.freehackers.org/Packaging_a_python_program

Feb 18 '08 #5
In article <0f**********************************@u72g2000hsf. googlegroups.com>,
BlueBird <ph**@freehackers.orgwrote:
>
I wrote a small wiki page to sum-up my findings about such typical
problem:

http://www.freehackers.org/Packaging_a_python_program
Excellent references, but maybe a bit of overkill. Everybody in my
target audience has python on their systems, I just want to send a
single .py (or .pyc) file so there's no complicated install procedure.

I mean, how *are* large python programs normally distributed under Linux?

--
-Ed Falk, fa**@despams.r.us.com
http://thespamdiaries.blogspot.com/
Feb 21 '08 #6
On Feb 21, 1:58 am, f...@green.rahul.net (Edward A. Falk) wrote:
In article <0f3e4884-59f8-4db8-a2a3-6f6d4fc14...@u72g2000hsf.googlegroups.com>,

BlueBird <p...@freehackers.orgwrote:
I wrote a small wiki page to sum-up my findings about such typical
problem:
http://www.freehackers.org/Packaging_a_python_program

Excellent references, but maybe a bit of overkill. Everybody in my
target audience has python on their systems, I just want to send a
single .py (or .pyc) file so there's no complicated install procedure.
What's so complicated about "python setup.py install" ? Even that is
not strictly necessary for pure python packages; a user may just
unpack the archive, cd to the extracted directory and execute the
appropriate .py file(s).

George
Feb 21 '08 #7
Edward A. Falk schrieb:
In article <0f**********************************@u72g2000hsf. googlegroups.com>,
BlueBird <ph**@freehackers.orgwrote:
>I wrote a small wiki page to sum-up my findings about such typical
problem:

http://www.freehackers.org/Packaging_a_python_program

Excellent references, but maybe a bit of overkill. Everybody in my
target audience has python on their systems, I just want to send a
single .py (or .pyc) file so there's no complicated install procedure.

I mean, how *are* large python programs normally distributed under Linux?
By means of their package management. At least that's what many people
prefer.

But I don't get what's wrong with
you: python setup.py bdist_egg

your client: easy_install the.egg

Diez
Feb 21 '08 #8
In article <92**********************************@f47g2000hsd. googlegroups.com>,
George Sakkis <ge***********@gmail.comwrote:
>
What's so complicated about "python setup.py install" ? Even that is
not strictly necessary for pure python packages; a user may just
unpack the archive, cd to the extracted directory and execute the
appropriate .py file(s).
Aha. Completely forgot about setup.py.

Unfortunately, under Linux, all it seems to do is build a tarball for
me, which when unpacked produces several discrete .py files, leaving
me back where I started.

Anyway, I did what I should have done in the first place and trolled
/usr/bin to see how other people had done it.

It turns out there are a few answers: First, you can simply just produce
the program as a single .py file (which is what I wound up doing).

Second, you can put all the .py files other than the "main" one into
/usr/share/<programnameand then append that directory to your
path before importing anything.

Third, you can put all the .py files other than the "main" one into
/usr/lib/python2.2/site-packages/<programnameand then you don't
have to modify your path.
The second and third methods have the advantage that you can have .pyc
files hanging around.
Anyway, thanks for all your input.

--
-Ed Falk, fa**@despams.r.us.com
http://thespamdiaries.blogspot.com/
Mar 4 '08 #9

This discussion thread is closed

Replies have been disabled for this discussion.

Similar topics

6 posts views Thread by Dave Patton | last post: by
10 posts views Thread by Ian Lazarus | last post: by
12 posts views Thread by Claude | last post: by
reply views Thread by not_a_commie | last post: by
By using this site, you agree to our Privacy Policy and Terms of Use.