Opened 7 years ago
Closed 6 years ago
#570 closed defect (fixed)
pip3
Reported by: | rduivenvoorde | Owned by: | |
---|---|---|---|
Priority: | major | Component: | Package |
Version: | Keywords: | ||
Cc: |
Description
After installing bare qgis-dev package, there is a 'pip3' command available, but it does not seem to work?
The installed the python-pip3 package, but still nog pip:
C:\osgeo4w64\bin> pip3 install lxml Fatal error in launcher: Unable to create process using '"'
https://trac.osgeo.org/osgeo4w/wiki/ExternalPythonPackages
still tells: install via python get-pip.py
what is a working way? Happy to fix the wiki if needed.
Attachments (1)
Change History (18)
comment:2 by , 6 years ago
Replying to muellea:
Inside the OSGeo4w-Shell you have to call py3_env and then e.g. pip3 - without the path information it works!
Correct - and that's how it's intended to work.
follow-up: 4 comment:3 by , 6 years ago
But only with a changed shebang inside the exe! That's the problem...
comment:4 by , 6 years ago
Replying to muellea:
But only with a changed shebang inside the exe! That's the problem...
Not if you call py3_env.bat
upfront.
follow-up: 8 comment:7 by , 6 years ago
unfortunately the same. Tried py3_env and call py3_env. In both cases i can start an interactive python-shell (python3), so environment is set, but pip3 refuses to start.
follow-ups: 9 10 13 comment:8 by , 6 years ago
Replying to muellea:
unfortunately the same. Tried py3_env and call py3_env. In both cases i can start an interactive python-shell (python3), so environment is set, but pip3 refuses to start.
Not reproducable here:
run o-help for a list of available commands C:\Windows\System32>call py3_env.bat C:\Windows\System32>SET PYTHONPATH= C:\Windows\System32>SET PYTHONHOME=C:\OSGEO4~1\apps\Python36 C:\Windows\System32>PATH C:\OSGEO4~1\apps\Python36;C:\OSGEO4~1\apps\Python36\Scripts;C:\OSGEO4~1\apps\Python27\Scripts;C:\OSGEO4~1\bin;C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\system32\WBem C:\Windows\System32>pip3 Usage: pip3 <command> [options] ...
comment:10 by , 6 years ago
I did a fresh install and the error remains. The file pip3.exe contains a path to #!c:\qt\32\python\python.exe. Jef, are you sure this path doesn't exist on your computer?
comment:11 by , 6 years ago
I can confirm that \bin\pip3.exe
has that path - but apps\Python36\Scripts\pip3.exe
which should be before \bin
in PATH
has the correct path. Are you starting it explictly from bin
?
comment:12 by , 6 years ago
they all have the same path (shebang) here, pip3 in Scripts comes first in the path variable set by py3_env.bat, so this will execute, and no i'm not in bin. If I install python3 from python.org, the path (shebang) is set during install and points to whatever installation dir i use for python. But I think this is not a part in postinstall of the osgeo4w package, so path(shebang) remains.
Some executables, like jupiter.exe, point to c:\osgeo4w\bin\python3.exe which is correct for an unchanged installation directory.
By the way: the idea to change the shebang manually cames from a q/a on stackexchange
So, as written there, simply using python -m pip inside a pip.bat would do the job, too.
follow-up: 16 comment:13 by , 6 years ago
Replying to jef:
Replying to muellea:
unfortunately the same. Tried py3_env and call py3_env. In both cases i can start an interactive python-shell (python3), so environment is set, but pip3 refuses to start.
Not reproducable here:
run o-help for a list of available commands C:\Windows\System32>call py3_env.bat C:\Windows\System32>SET PYTHONPATH= C:\Windows\System32>SET PYTHONHOME=C:\OSGEO4~1\apps\Python36 C:\Windows\System32>PATH C:\OSGEO4~1\apps\Python36;C:\OSGEO4~1\apps\Python36\Scripts;C:\OSGEO4~1\apps\Python27\Scripts;C:\OSGEO4~1\bin;C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\system32\WBem C:\Windows\System32>pip3 Usage: pip3 <command> [options] ...
tested here:
run o-help for a list of available commands C:\>call py3_env.bat C:\>SET PYTHONPATH= C:\>SET PYTHONHOME=C:\OSGEO4~1\apps\Python36 C:\>PATH C:\OSGEO4~1\apps\Python36;C:\OSGEO4~1\apps\Python36\Scripts;{app};C:\OSGEO4~1\apps\Python27\Scripts;C:\OSGEO4~1\bin;C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\system32\WBem;C:\OSGEO4~1\apps\msys\bin;C:\Program Files\R\R-3.4.4\bin\x64 C:\>pip3 Fatal error in launcher: Unable to create process using '"' C:\>
ckecked in the OSGeo4W installer wizard, pip3 isn't installed.
comment:14 by , 6 years ago
I didn't install pip package either. But pip is installed with the python3-core package, I think. Anyway, try python3 -m pip. This will start pip from site-sitepackages. The problem is with the exe files only.
comment:15 by , 6 years ago
Ok, inside the python3-pip package the exe file pip.exe has a different path/shepang. It points to c:\osgeo4w\bin\python3. So, if this is the your installation folder, pip.exe should work. Unfortunately it doesn't work for me...
comment:16 by , 6 years ago
Replying to hellik:
tested here:
run o-help for a list of available commands C:\>call py3_env.bat C:\>SET PYTHONPATH= C:\>SET PYTHONHOME=C:\OSGEO4~1\apps\Python36 C:\>PATH C:\OSGEO4~1\apps\Python36;C:\OSGEO4~1\apps\Python36\Scripts;{app};C:\OSGEO4~1\apps\Python27\Scripts;C:\OSGEO4~1\bin;C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\system32\WBem;C:\OSGEO4~1\apps\msys\bin;C:\Program Files\R\R-3.4.4\bin\x64 C:\>pip3 Fatal error in launcher: Unable to create process using '"' C:\>ckecked in the OSGeo4W installer wizard, pip3 isn't installed.
now installed pip3 via the OSGeo4W-installation wizard:
run o-help for a list of available commands C:\>call py3_env.bat C:\>SET PYTHONPATH= C:\>SET PYTHONHOME=C:\OSGEO4~1\apps\Python36 C:\>PATH C:\OSGEO4~1\apps\Python36;C:\OSGEO4~1\apps\Python36\Scripts;{app};C:\OSGEO4~1\apps\Python27\Scripts;C:\OSGEO4~1\bin;C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\system32\WBem;C:\OSGEO4~1\apps\msys\bin;C:\Program Files\R\R-3.4.4\bin\x64 C:\>pip3 Usage: pip3 <command> [options] Commands: install Install packages. download Download packages. uninstall Uninstall packages. freeze Output installed packages in requirements format. list List installed packages. show Show information about installed packages. check Verify installed packages have compatible dependencies. config Manage local and global configuration. search Search PyPI for packages. wheel Build wheels from your requirements. hash Compute hashes of package archives. completion A helper command used for command completion. help Show help for commands. General Options: -h, --help Show help. --isolated Run pip in an isolated mode, ignoring environment variables and user configuration. -v, --verbose Give more output. Option is additive, and can be used up to 3 times. -V, --version Show version and exit. -q, --quiet Give less output. Option is additive, and can be used up to 3 times (corresponding to WARNING, ERROR, and CRITICAL logging levels). --log <path> Path to a verbose appending log. --proxy <proxy> Specify a proxy in the form [user:passwd@]proxy.server:port. --retries <retries> Maximum number of retries each connection should attempt (default 5 times). --timeout <sec> Set the socket timeout (default 15 seconds). --exists-action <action> Default action when a path already exists: (s)witch, (i)gnore, (w)ipe, (b)ackup, (a)bort). --trusted-host <hostname> Mark this host as trusted, even though it does not have valid or any HTTPS. --cert <path> Path to alternate CA bundle. --client-cert <path> Path to SSL client certificate, a single file containing the private key and the certificate in PEM format. --cache-dir <dir> Store the cache data in <dir>. --no-cache-dir Disable the cache. --disable-pip-version-check Don't periodically check PyPI to determine whether a new version of pip is available for download. Implied with --no-index. --no-color Suppress colored output
it works as expected
comment:17 by , 6 years ago
Resolution: | → fixed |
---|---|
Status: | new → closed |
i found that all python-executables in OSGeo4W/apps/Python36/Scripts have wrong shebangs (#!). There pathes point to python executables, that may do not exist. I used an editor (notepad++) and opened the exe files, at the bottom one can find the shebang string. These I changed to #!python3.exe.
Inside the OSGeo4w-Shell you have to call py3_env and then e.g. pip3 - without the path information it works!
A solution could be to build the executables with a different shebang. Don't know if this could be done easily?