question-mark
Stuck on an issue?

Lightrun Answers was designed to reduce the constant googling that comes with debugging 3rd party libraries. It collects links to all the places you might be looking at while hunting down a tough bug.

And, if you’re still stuck at the end, we’re happy to hop on a call to see how we can help out.

Consider using the "py.exe" launcher to find Python 3 as well, not just for Python 2

See original GitHub issue
  • Node Version: Applies to any versions of Node/NPM, but tested on Node 10.20.1 with npm 6.14.4
  • Platform: This is about Windows, in general. Tested on Windows 10.
  • Compiler: N/A; this is just about finding a Python binary. No compiler needed on the system to find a Python binary.
  • Module: Nothing, just did findPython = require(./lib/find-python) in a little standalone .js script to test Python detection.
My script ("fpy.js") (to be saved to/called from the node-gyp repo's main folder, like so: "node fpy.js".)
findPython = require('./lib/find-python')

findPython(null, function (err, found) {
  if (err) {
    console.error(err)
  } else {
    python = found
    console.log('python was found: ' + python)
  }
})
Verbose output (from npm or node-gyp):
node.exe ./fpy.js
ERR! find Python
ERR! find Python Python is not set from command line or npm configuration
ERR! find Python Python is not set from environment variable PYTHON
ERR! find Python checking if "python3" can be used
ERR! find Python - "python3" is not in PATH or produced an error
ERR! find Python checking if "python" can be used
ERR! find Python - "python" is not in PATH or produced an error
ERR! find Python checking if "python2" can be used
ERR! find Python - "python2" is not in PATH or produced an error
ERR! find Python checking if Python is C:\Python37\python.exe
ERR! find Python - "C:\Python37\python.exe" could not be run
ERR! find Python checking if Python is C:\Python27\python.exe
ERR! find Python - "C:\Python27\python.exe" could not be run
ERR! find Python checking if the py launcher can be used to find Python 2
ERR! find Python - "py.exe" is not in PATH or produced an error
ERR! find Python
ERR! find Python **********************************************************
ERR! find Python You need to install the latest version of Python.
ERR! find Python Node-gyp should be able to find and use Python. If not,
ERR! find Python you can try one of the following options:
ERR! find Python - Use the switch --python="C:\Path\To\python.exe"
ERR! find Python   (accepted by both node-gyp and npm)
ERR! find Python - Set the environment variable PYTHON
ERR! find Python - Set the npm configuration variable python:
ERR! find Python   npm config set python "C:\Path\To\python.exe"
ERR! find Python For more information consult the documentation at:
ERR! find Python https://github.com/nodejs/node-gyp#installation
ERR! find Python **********************************************************
ERR! find Python
Error: Could not find any Python installation to use
    at PythonFinder.fail (C:\Users\[User]\node-gyp\lib\find-python.js:307:47)
    at PythonFinder.runChecks (C:\Users\[User]\node-gyp\lib\find-python.js:136:21)
    at PythonFinder.<anonymous> (C:\Users\[User]\node-gyp\lib\find-python.js:205:18)
    at PythonFinder.execFileCallback (C:\Users\[User]\node-gyp\lib\find-python.js:271:16)
    at ChildProcess.exithandler (child_process.js:301:5)
    at ChildProcess.emit (events.js:198:13)
    at maybeClose (internal/child_process.js:982:16)
    at Process.ChildProcess._handle.onexit (internal/child_process.js:259:5)

Intro, Background, and the Gist of it

Hi folks, I’m wondering if the node-gyp team would be interested in using the py.exe launcher to find not only/exclusively Python 2, like it does now, but potentially Python 3 as well.

(I just installed Python 3.8 from python.org, in the default install location, and node-gyp can’t find it. py.exe can find it, though.)

Apparently, judging by the commit history, using the Python launcher strictly to find Python 2 dates back just over four years ago, to BEFORE node-gyp had any support for Python 3. From here: https://github.com/nodejs/node-gyp/pull/894 (The latest published version of node-gyp would have been v3.3.1 at the time, judging by the release history: https://github.com/nodejs/node-gyp/releases?after=v3.5.0)

Thus, I assume the justification for only finding Python 2 at that time would have been the following: “node-gyp can’t work with Python 3, so finding Python 3 would be counter-productive! We must only find Python 2…” (That’s no longer true, and I think it might be nice to find Python 3 with such a convenient helper/launcher like py.exe.)


About the py.exe Launcher, and the installation location of Python on Windows

The py.exe launcher is quite useful for finding Python. It claims to be able to find the version downloadable from python.org AND the Python downloadable from the Windows Store. Source: https://docs.python.org/3/using/windows.html#launcher) It comes with Python installers for Windows since Python 3.3.

The Python situation on Windows is a little odd now, because it seems it used to be saved under something like C:\Python[Maj[Min]\python.exe (for example: C:\Python37), but recent installers save to somewhere more like this: 'C:\Users\[User]\AppData\Local\Programs\Python\Python38-32' and in fact, the location can be customized during the install wizard. So it could end up anywhere, I guess.

I think the launcher might be the most reliable way to find Python on Windows these days. And in any case, it makes an excellent fallback. I only find that it is a shame that it isn’t being used to find Python 3.

Indeed, going to Python.org, downloading Python 3.8.x and installing it will result in a Python installation that node-gyp can’t find. I would like to approximate node-gyp’s Python finding algorithm (or require its find-python.js file directly), but not being able to find the default install location from python.org seems somehow not right. I didn’t want to re-implement what seems like a (small) oversight in the repo I’m working on.

I do think the Python from the Windows Store might end up on the path as python and/or python3, but I haven’t tested or confirmed this.


Suggested Solution / Notes on an Implementation

Sorry I’m not very good with JS, or I’d whip up an implementation for a PR. But I think you could really just drop the -2 here, and update the comment above that, and that should do it.

(If that solution would be sufficient, or you’d like to see it run it through the CI tests and such, I would be GLAD to whip that up as a PR.)

From a quick read of the documentation page, the py.exe launcher seems to prefer Python 3 over Python 2, so just dropping the -2 flag might not be appropriate for for the node-gyp 5.x branch (which, from what I can see, generally prefers Python 2 over Python 3.)

Issue Analytics

  • State:closed
  • Created 3 years ago
  • Comments:12 (12 by maintainers)

github_iconTop GitHub Comments

1reaction
cclausscommented, May 15, 2020

There are several documented ways to get node-gyp to use the Python that you want. Perhaps it would be better to encourage npm/cli to upgrade to node-gyp v6 so we can retire v5.

0reactions
DeeDeeGcommented, May 17, 2020

Here’s a proof of concept implementation against the v5.x branch: https://github.com/DeeDeeG/node-gyp/commit/b2119e3896aa2a1c25df8a02b63bc770a47b7f89

I have tested it, and it works as intended, but it also does appear to break the tests.

Read more comments on GitHub >

github_iconTop Results From Across the Web

Possible bug with py.exe launcher in 3.11 - Python Help
I noticed a change with py.exe for Windows in Python 3.11. ... The new launcher tries to search PATH for “python3.exe” and falls...
Read more >
py launcher does not find my Python 2.7 - Stack Overflow
I tried installing 2.7. 8 in a nonstandard directory (literally C:\Python_non_standard_directory ) and made sure the Add python.exe to Path ...
Read more >
3. Using Python on Windows
You should find the latest version of Python 2.x starts. If you see the following error, you do not have the launcher installed:...
Read more >
How to use Python's py launcher for Windows - InfoWorld
The Windows version of the Python interpreter can be run from the command line the same way it's run in other operating systems, ......
Read more >
How to install python 3 on windows and set the path - YouTube
This is a quick video to show you how to install python 3 on windows and set the path to get it working...
Read more >

github_iconTop Related Medium Post

No results found

github_iconTop Related StackOverflow Question

No results found

github_iconTroubleshoot Live Code

Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free

github_iconTop Related Reddit Thread

No results found

github_iconTop Related Hackernoon Post

No results found

github_iconTop Related Tweet

No results found

github_iconTop Related Dev.to Post

No results found

github_iconTop Related Hashnode Post

No results found