Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
274 views
in Technique[技术] by (71.8m points)

python - Windows 10 and pip upgrading - Access denied

I have done a fresh Windows 10 install, installed python, cygwin and a improved console called ConEmu. After installing python 3.4.3 I execute:

pip install -U pip

And got this error.

File "C:AnwendungsentwicklungPython34libsite-packagespiputils\__init__.py", line 70, in rmtree_errorhandler
  os.makedirs(path)
PermissionError: [WinError 5] Zugriff verweigert:  'C:\Users\ADMINI~1\AppData\Local\Temp\pip-dxm8d3xg-uninstall\anwendungsentwicklung\python34\scripts\pip.exe'

I'm logged in with pre-defined Administrator account and the temp dir as well as the installation dir of Python (C:AnwendungsentwicklungPython34) has full access.

Please I have tested all variations by setting different rights but Windows won't let me. I even added "Everyone" to security tab but this didn't help although I remember it was working with Windows 7 with this "trick". It must be a problem with Windows 10. Can someone help??

enter image description here


This is full traceback

  Exception:
Traceback (most recent call last):
File "c:anwendungsentwicklungpython34libshutil.py", line 372, in  _rmtree_unsafe
  os.unlink(fullname)
PermissionError: [WinError 5] Zugriff verweigert:  'C:\Users\ADMINI~1\AppData\Local\Temp\pip-k7g0hd6t- uninstall\anwendungsentwicklung\python34\scripts\pip.exe'

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
File "c:anwendungsentwicklungpython34libsite-packagespipasecommand.py", line 232, in main
  logger.critical('Operation cancelled by user')
File "c:anwendungsentwicklungpython34libsite-packagespipcommandsinstall.py", line 347, in run
  ensure_dir(options.target_dir)
File "c:anwendungsentwicklungpython34libsite-packagespip
eq
eq_set.py", line 560, in install
  missing_requested = sorted(
File "c:anwendungsentwicklungpython34libsite-packagespip
eq
eq_install.py", line 677, in commit_uninstall
  logger.debug(
File "c:anwendungsentwicklungpython34libsite-packagespip
eq
eq_uninstall.py", line 153, in commit
  self.save_dir = None
File "c:anwendungsentwicklungpython34libsite-packagespiputils\__init__.py", line 58, in rmtree
  SUPPORTED_EXTENSIONS = ZIP_EXTENSIONS + TAR_EXTENSIONS
File "c:anwendungsentwicklungpython34libshutil.py", line 484, in rmtree
  return _rmtree_unsafe(path, onerror)
File "c:anwendungsentwicklungpython34libshutil.py", line 368, in _rmtree_unsafe
  _rmtree_unsafe(fullname, onerror)
File "c:anwendungsentwicklungpython34libshutil.py", line 368, in _rmtree_unsafe
  _rmtree_unsafe(fullname, onerror)
File "c:anwendungsentwicklungpython34libshutil.py", line 368, in _rmtree_unsafe
  _rmtree_unsafe(fullname, onerror)
File "c:anwendungsentwicklungpython34libshutil.py", line 376, in _rmtree_unsafe
  print(fullname)
File "c:anwendungsentwicklungpython34libsite-packagespiputils\__init__.py", line 70, in rmtree_errorhandler
  try:
PermissionError: [WinError 5] Zugriff verweigert: 'C:\Users\ADMINI~1\AppData\Local\Temp\pip-k7g0hd6t-uninstall\anwendungsentwicklung\python34\scripts\pip.exe'

Now I added a breakpoint in "c:anwendungsentwicklungpython34libshutil.py":

# version vulnerable to race conditions
def _rmtree_unsafe(path, onerror):
try:
    if os.path.islink(path):
        # symlinks to directories are forbidden, see bug #1669
        raise OSError("Cannot call rmtree on a symbolic link")
except OSError:
    onerror(os.path.islink, path, sys.exc_info())
    # can't continue even if onerror hook returns
    return
names = []
try:
    names = os.listdir(path)
except OSError:
    onerror(os.listdir, path, sys.exc_info())
for name in names:
    fullname = os.path.join(path, name)
    try:
        mode = os.lstat(fullname).st_mode
    except OSError:
        mode = 0
    if stat.S_ISDIR(mode):
        _rmtree_unsafe(fullname, onerror)
    else:
        try:
            #import pdb
            os.unlink(fullname)
            #pdb.set_trace()
        except OSError:
            import pdb; pdb.set_trace()
            print(fullname)
            import getpass
            print(getpass.getuser())
            onerror(os.unlink, fullname, sys.exc_info())
try:
    os.rmdir(path)
except OSError:
    onerror(os.rmdir, path, sys.exc_info())

When i execute

os.unlink(fullname) # 'C:\Users\ADMINI~1\AppData\Local\Temp\pip-k7g0hd6t- uninstall\anwendungsentwicklung\python34\scripts\pip.exe'

I get this PermissionError, so i checked the rights of this .exe file with

oct(os.stat(fullname)[ST_MODE])

and it returns: '0o100777'

And when i'm right, this means full permission for everyone (owner, group and others).

I'm frustrated :/ Someone an idea?

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

As discussed here, it's a Windows limitation. In brief, the pip.exe file is in use and thus locked and can't be deleted. Use python -m pip install --upgrade pip.


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...