-
Notifications
You must be signed in to change notification settings - Fork 2.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Include installation instructions for python3 #721
Comments
I installed poetry on Fedora 29 with curl -sSL https://raw.githubusercontent.com/sdispater/poetry/master/get-poetry.py | python3 but it's no use. |
@lqmanh if this is actively blocking you, just use |
This gets worse. I am on Ubuntu 18.04, and piped the get-poetry.py script to python3. I did not realize it until:
So despite having piped it to python3 it still installed under python2. How to change that behaviour? |
@mbello This has already been discussed extensively in other issues and PR. This is also mentionned in the documentation that Poetry will always use the currently activated Python executable to create the virtualenv. This has nothing to do with which python version you used to install Poetry. So I suggest using |
Ok, thanks for the pointer and sorry for bringing up an issue that seems to
have been discussed at great lengths already.
Just keep in mind that there is no such thing as 'activated python version'
in debian and ubuntu where python=python2 and python3=python3 always and
both are always 'activated'.
Then your installation instructions fail to address this issue and then you
get users like me wondering what went wrong.
pip3 install --user poetry did the trick for me though.
Thanks for poetry, love it.
Em sáb, 12 de jan de 2019 14:02, Sébastien Eustace <notifications@github.com
escreveu:
… @mbello <https://github.com/mbello> This has already been discussed
extensively in other issues and PR. This is also mentionned in the
documentation that Poetry will always use the currently activated Python
executable to create the virtualenv.
This has nothing to do with which python version you used to install
Poetry.
So I suggest using pyenv and use it to explicitly activate a Python
version or wait for the 1.0.0 release which will have the new env
command, see #731 <#731>
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#721 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AAndQFBVBjltYMrvATDsADHr78qSJBKuks5vCgckgaJpZM4ZKINf>
.
|
And that PEP 394 defines this as the standard way to name Python system binaries.
Me too :) |
Sorry @sdispater but the new version doesn't fix it.
the I update to the new one
I get the this waning from python2
I don't know what is this warning but for sure I shouldn't appear if poetry only uses the selected virtualenv. Finallay after monfying the sheebang line in
so clearly poetry is not always using the python version of the virtualenv. |
Modifying the poetry script to use python3 seemed to work for me. It defaults to "python" but if your project requires 3.x, poetry fails:
It's unfortunate to run into something like this within a few minutes of downloading... if the project requires 3.7, could poetry re-run itself under python3 with the same arguments? |
This is also a problem on "out-of-the-box" macOS, where I ran Which produced following
That is Which is pretty bad because trying to
|
I abandoned use of it for now. When it doesn't fail less than 5 minutes into use, I'll be back. |
Poetry uses your current python in order to create a matching virtualenv. If you want to use poetry NOW (pre-1.0.0 versions) then you should probably use something like pyenv (as recommended by @sdispater #721 (comment)). pyenv install 3.7.2 # Install python 3.7.2 to your machine
# Go to project root
pyenv local 3.7.2 # Use python 3.7.2 as default python in current open directory
poetry install # Will use default 'python', which is set to python3.7.2 |
As a first-time poetry user I ran into exactly this! When you search the documentation and past issues, the answer you always recieve is "just use pyenv". But I think this places an unnecessary restriction: it basically means you can't use poetry for a modern Python project unless you also commit to (a) using pyenv, (b) manually changing the shebang of poetry yourself, or (c) running poetry within a Python3 virtual environment. Pipenv behaves better here: if Python 3 is required for the project it'll find it if it's installed and use it. Sure, we could argue that this is out of the scope of poetry, but it's one of the first issues I hit and I'm sure others will too. |
It also feels kind of odd that Poetry, the most modern of package management tools, appears (to those first installing it on their system) be preferring python2 over python3, when python3 has been officially preferred for years, and is finally reaching something of a critical mass of adoption. |
I agree, if they insist on the current behavior they should at least default to using python3 when python2 and python3 are both available. Nowadays however you can run "poetry env use /usr/bin/python3". |
Still have the same set of issues with a clean install on Ubuntu 18.04. No "python" by default ... just python3. Even if I change .poetry/bin/poetry -> .poetry/bin/poetry3 I get error because distutils.util is missing when I try running "poetry env use /usr/bin/python3" as suggested above. And changing .poetry/bin/poetry makes me nervous because I imagine the when poetry updates itself in the future it will overwrite that. Bummer. Seemed really promising. Looking forward to returning once it matures a bit more. |
I've just hit this as well on a Fedora 30 system. They won't have migrated e.g. at https://github.com/sdispater/poetry/blob/master/get-poetry.py#L207:
|
Turns out I'm not the only one to think that approach might work: #1042 does functionally the same thing. |
When I ran that I got
|
Maybe setting the default python version to python3 may help.
Credit to @pardhu on https://stackoverflow.com/questions/41986507/unable-to-set-default-python-version-to-python3-in-ubuntu/50331137#50331137 |
This issue should not be confused with #536 . As far as I understand, this issue is about what python versions runs poetry itself, independently of what is the requirements of the managed project. One could use poetry, running system python3.7 and still manage projects in 2.7 or 3.6 managed by pyenv. I'm used to have curl get-foo.py | pythonX.Y to ensure that foo will be executed by the same interpreter as stated in the command line. Juste like pip3.7 will install your package for it's own running interpreter. why does get-poetry.py always write #1042 does the trick. |
I think that @bersace is right, the Python interpreter is used in two different contexts that should not be confused:
The Python interpreter used for running the The Python interpreter used for running Python projects should be determined by the virtual environment. The @sdispater introduced a separate However the implicit way is still broken. Poetry should implicitly create a built-in virtual environment with the Python version specified by the |
This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions. |
@sdispater solved this issue in PR #1477 (I have just tested it on the latest Poetry 1.0.0b5 on MacOS 10.15.1). @nottrobin could you close this issue? |
Great thanks! 🎉 |
Pretty dope! |
Why is it still an issue? Python 2 was deprecated in January 2020. A new version of poetry should come out with Python 3 support only! I installed Poetry yesterday (28 May 2020) and it broke on Ubuntu 20.04. |
This is fixed by #1878 . |
I think I'm still hitting this issue with poetry 1.0.8 - on Ubuntu 20.04 without python2 installed (and installing with Hacking the shebang of ~/.poetry/bin/poetry from python to python3 seems to fix it for me. |
Same here. I don't understand the point of running Poetry with anything else that |
The linked PR is currently only in the development branch. This will be available with the 1.1 release. |
Fair enough, sorry I noticed 1.0.8 was a new release & assumed this was part of it. |
Workaround for poetry's inability to find a proper python version. python-poetry/poetry#721
Workaround for poetry's inability to find a proper python version. python-poetry/poetry#721
Here on MacOs 10.15.7, Poetry 1.1.0. Despite installing with: I am still getting:
Might be because I previously installed it with |
@rarenatoe, it doesn't matter with which python executable you've installed poetry. |
Fixes python-poetry#3026 If the context wrapped by the temporary_directory() context manager raised ImportError (for example because distutils.util cannot be imported, python-poetry#721 python-poetry#1837), it would previously keep going, causing a RuntimeError from contextlib: RuntimeError: generator didn't stop after throw()
Fixes #3026 If the context wrapped by the temporary_directory() context manager raised ImportError (for example because distutils.util cannot be imported, #721 #1837), it would previously keep going, causing a RuntimeError from contextlib: RuntimeError: generator didn't stop after throw() Co-authored-by: Remi Rampin <r@remirampin.com>
Any pointers for the $ docker run --entrypoint /bin/bash -it 'ubuntu:latest'
$ apt update && apt install python-is-python3 curl
$ curl -sSL https://raw.githubusercontent.com/python-poetry/poetry/master/get-poetry.py | python -
$ source $HOME/.poetry/env
$ poetry -v
Traceback (most recent call last):
File "/root/.poetry/bin/poetry", line 17, in <module>
from poetry.console import main
File "/root/.poetry/lib/poetry/console/__init__.py", line 1, in <module>
from .application import Application
File "/root/.poetry/lib/poetry/console/application.py", line 7, in <module>
from .commands.about import AboutCommand
File "/root/.poetry/lib/poetry/console/commands/__init__.py", line 4, in <module>
from .check import CheckCommand
File "/root/.poetry/lib/poetry/console/commands/check.py", line 2, in <module>
from poetry.factory import Factory
File "/root/.poetry/lib/poetry/factory.py", line 18, in <module>
from .repositories.pypi_repository import PyPiRepository
File "/root/.poetry/lib/poetry/repositories/pypi_repository.py", line 33, in <module>
from ..inspection.info import PackageInfo
File "/root/.poetry/lib/poetry/inspection/info.py", line 25, in <module>
from poetry.utils.env import EnvCommandError
File "/root/.poetry/lib/poetry/utils/env.py", line 20, in <module>
import packaging.tags
File "/root/.poetry/lib/poetry/_vendor/py3.8/poetry/core/_vendor/packaging/tags.py", line 7, in <module>
import distutils.util
ModuleNotFoundError: No module named 'distutils.util' Edit: This resolved it:
|
This has still not been solved over a year after Python2 was deprecated. Poetry defaults to my Python2.7 installation over Python3.9. I honestly don't know how to fix an issue I got two minutes into using Poetry. |
I ran:
and then got:
Is there still no solution for this outside of making "python" be python3? (which isn't the default on OSX and would certainly break some things). I know I can manually edit |
I've never used pyenv, why should I need it just for this? I'm a little confused. |
@sinoroc I don't think using pyenv is a very good option/solution for this. The value of using poetry instead of pip is that you can install it globally and utilize it for all your projects. If you have to use pyenv and activate specific versions of python in every shell you open to interact with poetry then a lot of the value is lost. You might as well just manage your own virtualenv and use pip. |
I don't know. I don't use pyenv. I rarely use poetry. But as far as I understood, this is the intended workflow if you use the If you have issues with that, I would recommend using something like pipx (or dephell jails) to install poetry (and other similar tools, such as virtualenv, tox, pipenv, pex, shiv, etc.). |
This issue has been automatically locked since there has not been any recent activity after it was closed. Please open a new issue for related bugs. |
Issue
The README states as the ideal way to install Poetry:
curl -sSL https://raw.githubusercontent.com/sdispater/poetry/master/get-poetry.py | python
But, on an Ubuntu Xenial system with only Python 3 installed, this leads to the error
bash: python: command not found
. If I simply pipe the curl command throughpython3
instead then it succeds, but then I get:$ poetry install /usr/bin/env: 'python': No such file or directory
This is because the top of the installed file at
$HOME/.poetry/bin/poetry
contains#! /usr/bin/env python
.If, instead, I install poetry with
pip3 install poetry
, thenhead -n 1 $(which poetry)
shows#!/usr/bin/python3
at the top of the file, which works perfectly.Ubuntu, from 18.04 Xenial onwards, includes only Python 3 by default. And the minimal version of Xenial doesn't come with Python out of the box at all.
If you install Python 3 on Ubuntu, the binary that's installed is
python3
.python
doesn't exist unless you've also installed Python 2. This deliberately follows PEP 394:Although the PEP states "python should be used in the shebang line only for scripts that are source compatible with both Python 2 and 3" I'm not sure that this is compatible with the statement "all distributions should ensure that python refers to the same target as python2", because this means that if a system doesn't have Python 2 then the
python
binary won't exist. I think scripts have to do their best to usepython3
if they know it's supported, and most I've encountered do.I think maybe it would be good if the suggested install command was:
Or maybe you could provide a bash script (if you can rely on
bash
being available on all relevant systems) so that you could hide the logic of determining the Python version from the user:curl -sSL https://raw.githubusercontent.com/sdispater/poetry/master/get-poetry.sh | bash
Or simply say in the README:
And that the script would set up the
poetry
binary with either#! /usr/bin/env python3
for Python 3, or#! /usr/bin/env python
for Python 2 (which would then allow for the possibility ofpython
changing to Python 3 at some point).The text was updated successfully, but these errors were encountered: