ImportError: No module named suds

Bryan picture Bryan · Sep 13, 2011 · Viewed 9.8k times · Source

Having trouble with py2exe importing the suds module, and narrowed it down to the following:

>>> imp.find_module('suds', sys.path)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ImportError: No module named suds

However, a simple import works fine:

>>> import suds
>>> suds.__version__
'0.4'

Here is my sys.path, which shows suds at 'C:\Python27\lib\site-packages\suds-0.4-py2.7.egg':

>>> pprint.pprint(sys.path)
['',
 'C:\\Python27\\lib\\site-packages\\pyyaml-3.10-py2.7-win32.egg',
 'C:\\Python27\\lib\\site-packages\\progressbar-2.3-py2.7.egg',
 'C:\\Python27\\lib\\site-packages\\sqlalchemy-0.7.2-py2.7-win32.egg',
 'C:\\Python27\\lib\\site-packages\\soappy-0.12.5-py2.7.egg',
 'C:\\Python27\\lib\\site-packages\\wstools-0.3-py2.7.egg',
 'C:\\Python27\\lib\\site-packages\\fpconst-0.7.2-py2.7.egg',
 'C:\\Python27\\lib\\site-packages\\python_ntlm-1.0.1-py2.7.egg',
 'C:\\Python27\\lib\\site-packages\\django-1.3-py2.7.egg',
 'C:\\Python27\\lib\\site-packages\\pyodbc-2.1.9-py2.7-win32.egg',
 'C:\\Python27\\lib\\site-packages\\suds-0.4-py2.7.egg',
 'C:\\Windows\\system32\\python27.zip',
 'C:\\Python27\\DLLs',
 'C:\\Python27\\lib',
 'C:\\Python27\\lib\\plat-win',
 'C:\\Python27\\lib\\lib-tk',
 'C:\\Python27',
 'C:\\Python27\\lib\\site-packages']

Confirmed that py2exe is installed under 2.7:

C:\Python27\Lib\site-packages>ls -l py2*
-rw-rw-rw-  1 BEARGLE 0  524 2008-11-10 14:40 py2exe-0.6.9-py2.7.egg-info

py2exe:
total 448
-rw-rw-rw-  1 BEARGLE 0  3092 2008-11-10 14:39 __init__.py
-rw-rw-rw-  1 BEARGLE 0  3177 2011-09-12 14:36 __init__.pyc
-rw-rw-rw-  1 BEARGLE 0  3177 2011-09-12 14:35 __init__.pyo
-rw-rw-rw-  1 BEARGLE 0  4582 2008-06-24 16:32 boot_com_servers.py
-rw-rw-rw-  1 BEARGLE 0  2898 2011-09-12 14:35 boot_com_servers.pyc
-rw-rw-rw-  1 BEARGLE 0  2898 2011-09-12 14:35 boot_com_servers.pyo
-rw-rw-rw-  1 BEARGLE 0  3584 2008-06-24 16:32 boot_common.py
-rw-rw-rw-  1 BEARGLE 0  2252 2011-09-12 14:35 boot_common.pyc
-rw-rw-rw-  1 BEARGLE 0  2252 2011-09-12 14:35 boot_common.pyo
-rw-rw-rw-  1 BEARGLE 0  2941 2008-06-24 16:32 boot_ctypes_com_server.py
-rw-rw-rw-  1 BEARGLE 0  2733 2011-09-12 14:35 boot_ctypes_com_server.pyc
-rw-rw-rw-  1 BEARGLE 0  2733 2011-09-12 14:35 boot_ctypes_com_server.pyo
-rw-rw-rw-  1 BEARGLE 0  7527 2008-06-24 16:32 boot_service.py
-rw-rw-rw-  1 BEARGLE 0  5081 2011-09-12 14:35 boot_service.pyc
-rw-rw-rw-  1 BEARGLE 0  4973 2011-09-12 14:35 boot_service.pyo
-rw-rw-rw-  1 BEARGLE 0 71838 2008-08-30 11:56 build_exe.py
-rw-rw-rw-  1 BEARGLE 0 48498 2011-09-12 14:35 build_exe.pyc
-rw-rw-rw-  1 BEARGLE 0 48330 2011-09-12 14:35 build_exe.pyo
-rw-rw-rw-  1 BEARGLE 0 30327 2011-09-13 09:16 mf.py
-rw-rw-rw-  1 BEARGLE 0 22999 2011-09-13 09:16 mf.pyc
-rw-rw-rw-  1 BEARGLE 0 22876 2011-09-12 14:35 mf.pyo
-rw-rw-rw-  1 BEARGLE 0 13312 2008-11-10 14:40 py2exe_util.pyd
drw-rw-rw-  2 BEARGLE 0  4096 2011-09-12 14:35 resources
-rwxrwxrwx  1 BEARGLE 0 17408 2008-11-10 14:40 run.exe
-rw-rw-rw-  1 BEARGLE 0 19456 2008-11-10 14:40 run_ctypes_dll.dll
-rw-rw-rw-  1 BEARGLE 0 19968 2008-11-10 14:40 run_dll.dll
-rw-rw-rw-  1 BEARGLE 0 20480 2008-11-10 14:40 run_isapi.dll
-rwxrwxrwx  1 BEARGLE 0 17408 2008-11-10 14:40 run_w.exe
drw-rw-rw-  8 BEARGLE 0  4096 2011-09-12 14:35 samples

Why isn't imp.find_module locating the suds module?

Answer

Bryan picture Bryan · Sep 13, 2011

Extracted the suds egg at:

C:\Python27\lib\site-packages\suds-0.4-py2.7.egg

and created C:\Python27\lib\site-packages\suds directory that contains source files. Module is now found:

>>> imp.find_module('suds')
(None, 'C:\\Python27\\lib\\site-packages\\suds', ('', '', 5))

py2exe build completes successfully. It appears that imp.find_module requires directory with module source files to exist, an egg file is not recognized.