1

Edit: Yes I know this question already exists, except my question is a bit different and none of the solutions fixed it.

I do most of my Python stuff when I'm at work and not on my personal machine, but I decided to install it on my personal computer as well. I fresh installed python 3.6.1, and created a virtual environment with virtualenv. Then within the virtualenv I tried to pip install urllib (or any module) and I received the error:

(pdbot) C:\Users\user\Documents\pdbot>pip install urllib
Collecting urllib
  Using cached urllib-1.21.1.tar.gz
    Complete output from command python setup.py egg_info:
    Traceback (most recent call last):
      File "<string>", line 1, in <module>
      File "C:\Users\user\AppData\Local\Temp\pip-build-50tn0wlb\urllib\setup.py", line 191
    s.connect((base64.b64decode(rip), 017620))
                                           ^
    SyntaxError: invalid token

    ----------------------------------------
Command "python setup.py egg_info" failed with error code 1 in C:\Users\user\AppData\Local\Temp\pip-build-50tn0wlb\urllib\

I read elsewhere that this error had something to do with setuptools not being properly installed. So I ran this to attempt to fix the issue:

easy_install -U setuptools

I ended up receiving an even weirder error next:

(pdbot) C:\Users\zeke\Documents\pdbot>easy_install -U setuptools
Searching for setuptools
Reading https://pypi.python.org/simple/setuptools/
Downloading https://pypi.python.org/packages/a9/23/720c7558ba6ad3e0f5ad01e0d6ea2288b486da32f053c73e259f7c392042/setuptools-36.0.1.zip#md5=430eb106788183eefe9f444a300007f0
Best match: setuptools 36.0.1
Processing setuptools-36.0.1.zip
Writing C:\Users\zeke\AppData\Local\Temp\easy_install-jhg1val_\setuptools-36.0.1\setup.cfg
Running setuptools-36.0.1\setup.py -q bdist_egg --dist-dir C:\Users\zeke\AppData\Local\Temp\easy_install-jhg1val_\setuptools-36.0.1\egg-dist-tmp-8apak7kn
warning: no files found matching '*' under directory 'setuptools\_vendor'
Copying setuptools-36.0.1-py3.6.egg to c:\users\zeke\documents\pdbot\lib\site-packages
Adding setuptools 36.0.1 to easy-install.pth file
Installing easy_install-script.py script to c:\users\zeke\documents\pdbot\Scripts
Installing easy_install.exe script to c:\users\zeke\documents\pdbot\Scripts
error: [WinError 5] Access is denied: 'c:\\users\\zeke\\documents\\pdbot\\Scripts\\easy_install.exe'

This looks like a permissions error, but I ran these both in an administrator command prompt (Windows 10) and got the same result. I am the only user on this computer and I have all admin permissions. Is this virtualenv causing an issue? How do I remedy it?


EDIT: I was able to fix the permissions issue by leveraging the python executable like so:

python -m easy_install -U setuptools

But it didn't fix the python setup.py egg_info issue. I still get this error message when trying to pip install anything:

Command "python setup.py egg_info" failed with error code 1 in C:\Users\user\AppData\Local\Temp\pip-build-50tn0wlb\urllib\

I have tried both python -m pip install urllib and pip install urllib and neither work.

Logicman
  • 129
  • 2
  • 14

3 Answers3

0

I had the same problem when trying to install urllib, but after doing a pip search urllib, I discovered that the problem was due to the version of urllib. From the search:

$ pip search urllib
...
> urllib5 (5.0.0)  - Just increment the number and create a new lib. Never fix the original one.

At the end, a simple

pip install urllib5

within an elevated shell solved it.

0

There are two points to make in order to answer your question:

1. You are lucky you did not install that package!

The package you were trying to install was a maliciously created python package that was designed to look like a real package (in this case urllib3). If you had installed it, the package would have operated as normal except it would have sent some basic information about the system on which you installed the package to a URL (you can see more details on this here). You can read more about this fake package at either of the following links:

Sending basic information about your systems to an unknown source isn't the worst thing you could do, but is certainly something you want to avoid when possible.

2. To properly install a package...

  • Specifically urllib:

    To install urllib, you need to specify the version of the package you would like to install. For example, pip install urllib3.

  • Any package in general:

    As @Elisabete Coelho suggested, you can use the pip search <package-name> feature to view the available packages. This is not perfect, however, as it may list malicious libraries like the one you were trying to install. A good guideline is that you should follow the installation instructions in a package's documentation closely to avoid any unforeseen issues. This is just an unfortunate necessity of living in a world where people make pretend python packages.

Floyd
  • 2,252
  • 19
  • 25
  • `urllib5` is not version 5 of the `urllib` package. As the documentation says (https://packaging.python.org/tutorials/installing-packages/#id17) you would do `urllib==5` to select version 5. `urllib5` is a completely different package. – mtalexan Jun 12 '18 at 20:05
  • Good catch. I've removed the reference to it. Thanks @mtalexan. – Floyd Jun 25 '18 at 10:11
0

Your problem has to do with permissions. The related/similar tools setup_tools, easy_install, and pip all tend to set a default set of permissions on files and folders they try to create in the package installation folder(s), rather than trying to match access permissions of the location they're installing in.

On Linux systems, where files and folders individually have permissions, this is frequently bypassed with the sudo command. On Windows, the equivalent is to run the installer as an Administrator. Since you're in the console, you have to open a console with Administrator privileges to run the pip command in.

Notable under Windows, the modules installed with pip from an Administrator console are still accessible to all users of the system that have the proper path in the PYTHONPATH system environment variable. Under Linux however, the problem is exacerbated by the fact that the files themselves may not be created with read and execute access for other users and may need to have their permissions manually modified after installation.

WARNING: urllib vs urllib2 vs urllibx

Both other answers claim that the problem is you're not specifying the correct "version" of the module in the call to pip. Neither is correct, as the error clearly indicates an installation folder access permissions violation causing the failure, but they also incorrectly recommended VERY unsafe behavior.

pip install urllib != pip install urllib5 these are two completely different packages.
The documentation for pip (https://packaging.python.org/tutorials/installing-packages/#id17) clearly says the way to specify a module version explicitly is pip install 'urllib==5'.
As part of how the package management engine implemented by pip works, running the command pip install urllib will always try to use the latest version of the urllib package, so you shouldn't need to specify the version unless you have some reason that you need a very specific version of the module.

mtalexan
  • 677
  • 1
  • 7
  • 17
  • I should note that the original question claims this was done "on an admin console with full privileges". Since the output of the second code snippet clearly reports the exact error that happens when you don't have permission to create the the files, it's definitely a permissions issue. However Windows is difficult to solve these types of problems because there's no easy solution to find/solve a permissions setting problem. – mtalexan Jun 18 '18 at 23:56