| Size: 5891 Comment: Added links to getting started with Python and the command prompt. | Size: 11609 Comment: Add a huge section detailing how to provide the MS visual C runtime | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 5: | Line 5: | 
| To successfully complete this tutorial you'll need to know the basics of Python (you can get started at python.org's [http://www.python.org/about/gettingstarted/ getting started] page). You'll also need to know [http://www.python.org/doc/faq/windows/#how-do-i-run-a-python-program-under-windows how to run Python programs from the command prompt]. | To successfully complete this tutorial you'll need to know the basics of Python (you can get started at python.org's [[http://www.python.org/about/gettingstarted/|getting started]] page). You'll also need to know [[http://www.python.org/doc/faq/windows/#how-do-i-run-a-python-program-under-windows|how to run Python programs from the command prompt]]. | 
| Line 9: | Line 9: | 
| 1. [#Step1 Create/test your program] 2. [#Step2 Create your setup script (setup.py)] 3. [#Step3 Run your setup script] 4. [#Step4 Test your executable] 5. [#Step5 Build an installer if applicable] [[Anchor(Step1)]] == Create/test your program == | 1. [[#Step1|Create/test your program]] 2. [[#Step2|Create your setup script (setup.py)]] 3. [[#Step3|Run your setup script]] 4. [[#Step4|Test your executable]] 5. [[#Step5|Providing the Microsoft Visual C runtime DLL]] 5.1. [[#Step51|Python 2.4 or 2.5]] 5.2. [[#Step52|Python 2.6 and newer]] 5.2.1. [[#Step521|Bundling the C runtime DLL]] 5.2.2. [[#Step522|Running the redistributable C runtime installer]] 6. [[#Step6|Build an installer if applicable]] <<Anchor(Step1)>> == 1. Create/test your program == | 
| Line 26: | Line 31: | 
| }}}attachment:hello.py | }}} [[attachment:hello.py]] | 
| Line 32: | Line 39: | 
| Hello World | Hello World! | 
| Line 39: | Line 46: | 
| [[Anchor(Step2)]] == Create your setup script (setup.py) == py2exe extends [http://www.python.org/doc/current/dist/ Distutils] with a new "command". If you've installed third party Python modules then there's a good chance you've seen at least one distutils command: {{{ C:\>python setup.py install | <<Anchor(Step2)>> == 2. Create your setup script (setup.py) == py2exe extends [[http://www.python.org/doc/current/dist/|Distutils]] with a new "command". If you've installed third party Python modules then there's a good chance you've seen at least one distutils command: {{{ C:\Tutorial>python setup.py install | 
| Line 50: | Line 57: | 
| "py2exe" is a new Distutils command that is added when you import py2exe. To use py2exe you need to create a setup.py file to tell Distutils and py2exe what you want to do. Here's a setup.py who's simplicity is appropriate for our sample program... | "py2exe" is a new Distutils command that is added when you import py2exe. To use py2exe you need to create a setup.py file to tell Distutils and py2exe what you want to do. Here's a setup.py whose simplicity is appropriate for our sample program... | 
| Line 57: | Line 64: | 
| }}}attachment:setup.py | }}} [[attachment:setup.py]] | 
| Line 66: | Line 75: | 
| [[Anchor(Step3)]] == Run your setup script == | <<Anchor(Step3)>> == 3. Run your setup script == | 
| Line 108: | Line 117: | 
| Two directories will be created when you run your setup script... build and dist. The build directory is used as working space while your application is being packaged. It is safe to delete the build directory after your setup script has finished running. The files in the dist directory are the ones needed to run your application. If you are using Python 2.4 or newer then MSVCR71.dll will be included in dist - this is a Microsoft DLL and you need to determine if you have the legal right to distribute it. [[Anchor(Step4)]] == Test your executable == | Two directories will be created when you run your setup script, build and dist. The build directory is used as working space while your application is being packaged. It is safe to delete the build directory after your setup script has finished running. The files in the dist directory are the ones needed to run your application. <<Anchor(Step4)>> == 4. Test your executable == | 
| Line 123: | Line 132: | 
| [[Anchor(Step5)]] == Build an installer if applicable == py2exe is not an installer builder - it merely assembles the files needed to run your Python program. There are plenty of good installer builders out there including some that are open source (e.g., [http://nsis.sourceforge.net/Main_Page NSIS]) and some that are free (e.g., [http://www.jrsoftware.org/isinfo.php Inno Setup]). | <<Anchor(Step5)>> == 5. Providing the Microsoft Visual C runtime DLL == Your new program will only work on computers that already have the Microsoft Visual C runtime DLL installed. If you have installed Python or Visual Studio, you will already have this DLL. If all of your users already have it, then you can skip all of step 5. If some of your users may not already have this DLL, they will not be able to run your program. The methods you may use to solve this depend on the version of Python you are using: <<Anchor(Step51)>> === 5.1. Python 2.4 or 2.5 === If you are using Python 2.4 or 2.5, then the DLL you need is called MSVCR71.dll. Py2exe has already included this file in your dist directory, and you need do nothing more. However, the copyright on this file is owned by Microsoft, and you need to check whether you have the legal right to redistribute it. If you have a copy of Visual Studio, check the file redist.txt provided within the installation to see whether you have redistribution rights for this DLL. Generally you have the right to redistribute it if you own a license for Microsoft Visual C++, but not if you use the Express Editions. If you do not have the rights to redistribute MSVCR71.dll, then see [[#Step522|section 5.2.2 below]] on how your users can obtain it by downloading and running vcredist_x86.exe. ('''TODO:''' is it important which version of vcredist_x86.exe they download? VS2005? 2008? SP1? etc) <<Anchor(Step52)>> === 5.2. Python 2.6 and newer === For Python 2.6, the DLL you need is called MSVCR90.dll. Py2exe is not able to automatically include this DLL in your dist directory, so you must provide it yourself. To complicate things, there is more than one version of this DLL in existance, each with the same filename. You need the same version that the Python interpreter was compiled with, which is version 9.0.21022.8. Through the remainder of these instructions, hover your mouse over the dll file (or the vcredist_x86.exe installer executable) to confirm which version you've got. As for older versions of Python, you need to check redist.txt within your Visual Studio installation to see whether you have the legal right to redistribute this DLL. If you do have these rights, then you have the option to bundle the C runtime DLL with you application. If you don't have the rights, then you must have your users run the redistributable C runtime installer on their machines. <<Anchor(Step521)>> ==== 5.2.1. Bundling the C runtime DLL ==== If you do have the rights to redistribute MSVCR90.dll, there should be a copy of it in your Visual Studio install, under VC\redist\x86\Microsoft.VC90.CRT. Since Visual Studio 2008, you can't just copy this DLL file - you also need the manifest file that you'll find there. Make a copy of everything in the 'Microsoft.VC90.CRT' directory, for example into your project tree, or in some location that is shared between projects, such as "C:\dev\ms-visualc-runtime". There are two other DLL files in there (msvcm90.dll and msvcp90.dll) that you don't need. Delete these from your copy, and optionally you may remove the two <file> tags in the manifest file that refer to them. The manifest file should then look like this: {{{ <?xml version="1.0" encoding="UTF-8" standalone="yes"?> <!-- Copyright (c) Microsoft Corporation. All rights reserved. --> <assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0"> <noInheritable/> <assemblyIdentity type="win32" name="Microsoft.VC90.CRT" version="9.0.21022.8" processorArchitecture="x86" publicKeyToken="1fc8b3b9a1e18e3b" /> <file name="msvcr90.dll" /> </assembly> }}} Now, we want py2exe to copy MSVCR90.dll and the manifest file into your project's dist directory, in a subdirectory called 'Microsoft.VC90.CRT'. To achieve this, add a data_files option to your project's setup.py: {{{ from glob import glob data_files = [("Microsoft.VC90.CRT", glob(r'c:\dev\ms-vc-runtime\*.*')] setup( data_files=data_files, etc ) }}} With this in place, running py2exe should put the files into your dist directory: {{{ dist | +-Microsoft.VC90.CRT | | | +-Microsoft.VC90.CRT.manifest | +-msvcr90.dll | |-etc }}} Now, simply copying the whole dist directory to your users machines should now allow your application to run, even on machines that don't have their own copy of the C++ runtime. Note that this method of including the C runtime is used by several Visual C++ applications - if you search your Program Files folder for msvcr90.dll, you may find several applications that have this DLL and the associated manifest bundled alongside their executable like this. <<Anchor(Step522)>> ==== 5.2.2. Running the redistributable C runtime installer ==== If you don't have rights to redistribute MSVCR90.dll, then your users may install it on their machine by running the [[http://www.microsoft.com/downloads/details.aspx?FamilyID=9b2da534-3e03-4391-8a4d-074b9f2bc1bf&displaylang=en|Microsoft Visual C++ 2008 Redistributable Package]]. It is important not to use the SP1 version of this installer, which contains the wrong version of MSVCR90.dll. Either you can instruct your users to download and run this themselves, or you could create an installer for your application ([[#Step6|see below]]), that includes vcredist_x86.exe (which is itself redistributable by anyone), and which runs it when installing your application. <<Anchor(Step6)>> == 6. Build an installer if applicable == py2exe is not an installer builder - it merely assembles the files needed to run your Python program. There are plenty of good installer builders out there including some that are open source (e.g., [[http://nsis.sourceforge.net/Main_Page|NSIS]]) and some that are free (e.g., [[http://www.jrsoftware.org/isinfo.php|Inno Setup]]). | 
Tutorial
py2exe turns Python programs into packages that can be run on other Windows computers without needing to install Python on those computers. Python is needed on the computer where py2exe itself is run because py2exe is a Python program and it includes parts of Python in the package that is built.
To successfully complete this tutorial you'll need to know the basics of Python (you can get started at python.org's getting started page). You'll also need to know how to run Python programs from the command prompt.
There are a few simple steps needed to use py2exe once you've installed it:
1. Create/test your program
The biggest step is almost always the first one. The good news is that py2exe typically has little or no impact on this step. The vast majority of things you can do with Python will work with py2exe. Many modules just work seamlessly with py2exe, but some third party modules will require a little extra work. Luckily there is help available at WorkingWithVariousPackagesAndModules.
It's important that you make sure everything is working before you use py2exe. If py2exe fixes a broken program, then that's probably a bug in py2exe that needs to be fixed!
The first example we'll use here is our old friend...
   1 print "Hello World!"
We need to make sure it's working...
C:\Tutorial>python hello.py Hello World! C:\Tutorial>
Looks good!
2. Create your setup script (setup.py)
py2exe extends Distutils with a new "command". If you've installed third party Python modules then there's a good chance you've seen at least one distutils command:
C:\Tutorial>python setup.py install
"install" is a Distutils command that installs something (typically a Python module or package). The details Distutils needs to do that installation are contained in setup.py (and sometimes other associated files).
"py2exe" is a new Distutils command that is added when you import py2exe. To use py2exe you need to create a setup.py file to tell Distutils and py2exe what you want to do. Here's a setup.py whose simplicity is appropriate for our sample program...
Notice that this is ordinary Python. Let's go through it line by line...
- When working with py2exe the only part of Distutils we'll typically need to reference directly is the setup function, so that's all we'll import.
- Once Distutils is loaded, we need to load py2exe so that it can add its command.
- Whitespace is good!
- Call setup and tell it that we want a single console application and the main entry point is "hello.py".
3. Run your setup script
The next step is to run your setup script. Make sure to give the py2exe command and expect to see lots and lots of output:
C:\Tutorial>python setup.py py2exe running py2exe *** searching for required modules *** *** parsing results *** creating python loader for extension 'zlib' creating python loader for extension 'unicodedata' creating python loader for extension 'bz2' *** finding dlls needed *** *** create binaries *** *** byte compile python files *** byte-compiling C:\Tutorial\build\bdist.win32\winexe\temp\bz2.py to bz2.pyc byte-compiling C:\Tutorial\build\bdist.win32\winexe\temp\unicodedata.py to unicodedata.pyc byte-compiling C:\Tutorial\build\bdist.win32\winexe\temp\zlib.py to zlib.pyc skipping byte-compilation of c:\Python24\lib\StringIO.py to StringIO.pyc [skipping many lines for brevity] skipping byte-compilation of c:\Python24\lib\warnings.py to warnings.pyc *** copy extensions *** *** copy dlls *** copying c:\Python24\lib\site-packages\py2exe\run.exe -> C:\Tutorial\dist\hello.exe *** binary dependencies *** Your executable(s) also depend on these dlls which are not included, you may or may not need to distribute them. Make sure you have the license if you distribute any of them, and make sure you don't distribute files belonging to the operating system. ADVAPI32.dll - C:\WINDOWS\system32\ADVAPI32.dll USER32.dll - C:\WINDOWS\system32\USER32.dll SHELL32.dll - C:\WINDOWS\system32\SHELL32.dll KERNEL32.dll - C:\WINDOWS\system32\KERNEL32.dll C:\Tutorial>
Two directories will be created when you run your setup script, build and dist. The build directory is used as working space while your application is being packaged. It is safe to delete the build directory after your setup script has finished running. The files in the dist directory are the ones needed to run your application.
4. Test your executable
Now that the package has been created it is ready to test:
C:\Tutorial>cd dist C:\Tutorial\dist>hello.exe Hello World
Excellent, it works!!!
5. Providing the Microsoft Visual C runtime DLL
Your new program will only work on computers that already have the Microsoft Visual C runtime DLL installed. If you have installed Python or Visual Studio, you will already have this DLL. If all of your users already have it, then you can skip all of step 5. If some of your users may not already have this DLL, they will not be able to run your program. The methods you may use to solve this depend on the version of Python you are using:
5.1. Python 2.4 or 2.5
If you are using Python 2.4 or 2.5, then the DLL you need is called MSVCR71.dll. Py2exe has already included this file in your dist directory, and you need do nothing more.
However, the copyright on this file is owned by Microsoft, and you need to check whether you have the legal right to redistribute it. If you have a copy of Visual Studio, check the file redist.txt provided within the installation to see whether you have redistribution rights for this DLL. Generally you have the right to redistribute it if you own a license for Microsoft Visual C++, but not if you use the Express Editions.
If you do not have the rights to redistribute MSVCR71.dll, then see section 5.2.2 below on how your users can obtain it by downloading and running vcredist_x86.exe. (TODO: is it important which version of vcredist_x86.exe they download? VS2005? 2008? SP1? etc)
5.2. Python 2.6 and newer
For Python 2.6, the DLL you need is called MSVCR90.dll. Py2exe is not able to automatically include this DLL in your dist directory, so you must provide it yourself.
To complicate things, there is more than one version of this DLL in existance, each with the same filename. You need the same version that the Python interpreter was compiled with, which is version 9.0.21022.8. Through the remainder of these instructions, hover your mouse over the dll file (or the vcredist_x86.exe installer executable) to confirm which version you've got.
As for older versions of Python, you need to check redist.txt within your Visual Studio installation to see whether you have the legal right to redistribute this DLL. If you do have these rights, then you have the option to bundle the C runtime DLL with you application. If you don't have the rights, then you must have your users run the redistributable C runtime installer on their machines.
5.2.1. Bundling the C runtime DLL
If you do have the rights to redistribute MSVCR90.dll, there should be a copy of it in your Visual Studio install, under VC\redist\x86\Microsoft.VC90.CRT. Since Visual Studio 2008, you can't just copy this DLL file - you also need the manifest file that you'll find there.
Make a copy of everything in the 'Microsoft.VC90.CRT' directory, for example into your project tree, or in some location that is shared between projects, such as "C:\dev\ms-visualc-runtime".
There are two other DLL files in there (msvcm90.dll and msvcp90.dll) that you don't need. Delete these from your copy, and optionally you may remove the two <file> tags in the manifest file that refer to them. The manifest file should then look like this:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<!-- Copyright (c) Microsoft Corporation.  All rights reserved. -->
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
    <noInheritable/>
    <assemblyIdentity
        type="win32"
        name="Microsoft.VC90.CRT"
        version="9.0.21022.8"
        processorArchitecture="x86"
        publicKeyToken="1fc8b3b9a1e18e3b"
    />
    <file name="msvcr90.dll" />
</assembly>Now, we want py2exe to copy MSVCR90.dll and the manifest file into your project's dist directory, in a subdirectory called 'Microsoft.VC90.CRT'. To achieve this, add a data_files option to your project's setup.py:
  from glob import glob
  data_files = [("Microsoft.VC90.CRT", glob(r'c:\dev\ms-vc-runtime\*.*')]
  setup(
    data_files=data_files,
    etc
  )With this in place, running py2exe should put the files into your dist directory:
dist | +-Microsoft.VC90.CRT | | | +-Microsoft.VC90.CRT.manifest | +-msvcr90.dll | |-etc
Now, simply copying the whole dist directory to your users machines should now allow your application to run, even on machines that don't have their own copy of the C++ runtime.
Note that this method of including the C runtime is used by several Visual C++ applications - if you search your Program Files folder for msvcr90.dll, you may find several applications that have this DLL and the associated manifest bundled alongside their executable like this.
5.2.2. Running the redistributable C runtime installer
If you don't have rights to redistribute MSVCR90.dll, then your users may install it on their machine by running the Microsoft Visual C++ 2008 Redistributable Package. It is important not to use the SP1 version of this installer, which contains the wrong version of MSVCR90.dll.
Either you can instruct your users to download and run this themselves, or you could create an installer for your application (see below), that includes vcredist_x86.exe (which is itself redistributable by anyone), and which runs it when installing your application.
6. Build an installer if applicable
py2exe is not an installer builder - it merely assembles the files needed to run your Python program. There are plenty of good installer builders out there including some that are open source (e.g., NSIS) and some that are free (e.g., Inno Setup).

