Python SDK - Troubleshooting¶
Here are a few error message you could get, and a possible solution.
ImportError: No module named naoqi
You must have something wrong with your
PYTHONPATH environnement variable.
You can check this by typing:
import sys print "\n".join(sys.path)
You should see /path/to/python-sdk at the beginning of the list.
ImportError: ./_inaoqi.so: wrong ELF class: ELFCLASS32
You are using a 64 bits version of python.
ImportError: libpython2.6.so.1.0: cannot open shared object file: No such file or directory
You are using a Python2.7 with the python2.6 version of the Python SDK.
Your version of Python does not match the one with which the Python SDK was made.
On Mac, make sure
VERSIONER_PYTHON_PREFER_32_BITS is not set.
(While 1.10 needed this parameter ON, release 1.12 needs this parameter to be OFF)
Fatal Python error: PyThreadState_Get: no current thread¶
You are using a version of Python that is not binary compatible with the one used to compile the Python bindings.
If this happens on Mac, you should uninstall any Python versions you may have downloaded, and use the Python interpreter that comes with OS X.
If you want to be able to use
python from the command line, follow what the
README in the installer says, and double-click on the
Update Shell Profile command to add the “bin” directory inside the
framework to your shell’s search path.
Errors with ALProxy¶
RuntimeError: ALBrokerProxy::getBrokerInfo can not get broker info. Endpoint : http://nao.local:9559
Make sure NAOqi is running and the IP you used in
ALProxy constructor is correct
RuntimeError: ALNetwork::getModuleByName failed to get module MyModule http://nao.local:9559
Make sure you spelt the name of the module correctly.
File "naoqi.py", line 246, in method_missing raise e RuntimeError: ALTextToSpeech::sa ALBroker::methodCall: method: sa, params: ["hello"] ALTextToSpeech::sa Function sa does not exist in module ALTextToSpeech
Make sure you spelt the name of the function correctly.
To check the complete list of modules and method names, see section NAOqi APIs
Weird float errors¶
If you notice that floats are trucated when they are the result of the call of a bound methods, make sure that your locale is in english.
You can set LC_NUMERIC=’C’ for this
import locale locale.setlocale(locale.LC_NUMERIC, 'C')