19

I have created a .exe file of a simple script with intentions to run it on a server however I cannot seem to figure out what this fault means or find any answers online. The fault code is as follows:

Fatal Python error: initfsencoding: unable to load the file system codec
ModuleNotFoundError: No module named 'encodings'

Current thread 0x00003c8c (most recent call first):

To get this far I used pyinstaller

pyinstaller --onefile MyScript.py

When this didn't work I also tried

pyinstaller MyScript.py

I am running on windows 10, python 3.7 within admin command prompt, within a C:\ file directory.

My sys.path is

['', 'C:\Users\user\AppData\Local\Programs\Python\Python37-32\python37.zip', 'C:\Users\user\AppData\Local\Programs\Python\Python37-32\DLLs', 'C:\Users\user\AppData\Local\Programs\Python\Python37-32\lib', 'C:\Users\user\AppData\Local\Programs\Python\Python37-32', 'C:\Users\user\AppData\Roaming\Python\Python37\site-packages', 'C:\Users\user\AppData\Local\Programs\Python\Python37-32\lib\site-packages', 'C:\Users\user\AppData\Local\Programs\Python\Python37-32\lib\site-packages\win32', 'C:\Users\user\AppData\Local\Programs\Python\Python37-32\lib\site-packages\win32\lib', 'C:\Users\user\AppData\Local\Programs\Python\Python37-32\lib\site-packages\Pythonwin']

Any help is appreciated

6
  • 3
    Does your python launch when you type python in your cmd? Commented Jan 8, 2019 at 7:38
  • Yep python works, all env paths were correctly installed along with python Commented Jan 8, 2019 at 7:40
  • Can you paste your PYTHONHOME and PYTHONPATH from your system variables? Commented Jan 8, 2019 at 7:43
  • pythonhome- C:\Python37 pythonpath- C:\Users\esinclair\AppData\Local\Programs\Python\Python37-32 Commented Jan 8, 2019 at 7:50
  • I have added to the question what sys.path gives me Commented Jan 8, 2019 at 7:57

6 Answers 6

11

Looks like this is happening due to some problem in python installation. Are you sure python is configured properly? Did you add it into ENVIRONMENT VARIABLES?

Most likely it is because your PYTHONPATH ,i.e the one that locates the site-packages is improperly configured. It should work fine once you point PYTHONPATH to the corrent python3.x installation.

Once launch python from your cmd and check which site-packages it is loading.

import sys
sys.path

And then verify what is actually present in your PYTHONHOME

Sign up to request clarification or add additional context in comments.

8 Comments

I have edited the question to show what this gave me
I see the path is not the same. Your python sys.path - C:\Users\user\AppData and your system path do not match. C:\Users\esinclair\AppData. here the user didn't match
thats my fault i removed my name and entered user instead for the purpose of this, i missed one - the paths do all match in my terminal!
I suggest you load up a virtual environment with python 3.6 and run the script from there. Make sure you load python 3.6 in that virtualenv.
why would using python 3.6 make a difference?
|
2

I had the very same error message as EcSync. Although most people are pointing to the python setup being wrong this was not the case for me - aside from the fact that my system had not changed from one day to the next when I got the error, my environment variables matched the python sys.path

EcSync solved the problem by including a missing module but their answer is downvoted. I have to add my voice to say that this error was also caused by a missing module. The clue is in the error message:

Fatal Python error: initfsencoding: unable to load the file system codec
ModuleNotFoundError: No module named 'encodings'

I simply modified my spec file to include the encodings module and then everything worked. To do this you may need to specify to pyinstaller to use the spec file provided rather than making one from scratch, and you will have to put the path to the missing module in the datas list of Analysis. See here.

1 Comment

Your answer could be improved with additional supporting information. Please edit to add further details, such as citations or documentation, so that others can confirm that your answer is correct. You can find more information on how to write good answers in the help center.
1

I just added the following to the system variables:

PYTHONPATH ----------------------------C:\Python37

enter image description here

Comments

0

this error means that Py_SetPath forced python to use a path which doesn't include python38.zip, add the full pathname to python38.zip to the Py_SetPath, or don't use Py_SetPath and work with python38._pth instead.

#define PY_SSIZE_T_CLEAN
#include <Python.h>


int main(int argc char **argv)
{
        Py_SetPath(L"C:\\path-to\\python-3.8.5-embed-amd64\\python38.zip;C:\\path-to\\python-3.8.5-embed-amd64");
        Py_Initialize();
        // ...
}

Comments

0

Use --standalone will build the binary with whole python environment. You don't need a python install in the destination machine to run it.

Comments

-1

So I managed to fix this issue by rebuilding the exe file and dumping all of the site packages from python home to the exe dist folder. Will go through them again to figure out which one was causing issues.

EDIT

I narrowed this down and found the specific issue was the plotly package was not being dumped into the dist folder. I am not sure why but this is the only package I was using that pyinstaller wouldn't pick up

3 Comments

Hi, I am facing the same issue, can you tell me how did you rebuild exe file?
@SammyJ no need to rebuild, just insert missing package into dist folder
Does adding it as hidden import work? Did you make any changes in spec file?

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.