2014-01-16 60 views
4

每當我嘗試使用PIP我找不到任何類似這個問題。問題恰恰2個參數(3給出)

我得到這個異常(使用Scrapy爲例):

C:\Python27\Scripts\pip-script.py run on 01/16/14 16:26:32 
Requirement already satisfied (use --upgrade to upgrade): Scrapy in c:\python27\lib\site-packages\scrapy-0.20.2-py2.7.egg 
Requirement already satisfied (use --upgrade to upgrade): Twisted>=10.0.0 in c:\python27\lib\site-packages (from Scrapy) 
Downloading/unpacking w3lib>=1.2 (from Scrapy) 
    Getting page https://pypi.python.org/simple/w3lib/ 
    URLs to search for versions for w3lib>=1.2 (from Scrapy): 
    * https://pypi.python.org/simple/w3lib/ 
    Analyzing links from page https://pypi.python.org/simple/w3lib/ 
Cleaning up... 
    Removing temporary dir c:\users\tobias\appdata\local\temp\pip_build_Tobias... 
Exception: 
Traceback (most recent call last): 
    File "c:\python27\lib\site-packages\pip\basecommand.py", line 122, in main 
    status = self.run(options, args) 
    File "c:\python27\lib\site-packages\pip\commands\install.py", line 270, in run 
    requirement_set.prepare_files(finder, force_root_egg_info=self.bundle, bundle=self.bundle) 
    File "c:\python27\lib\site-packages\pip\req.py", line 1157, in prepare_files 
    url = finder.find_requirement(req_to_install, upgrade=self.upgrade) 
    File "c:\python27\lib\site-packages\pip\index.py", line 264, in find_requirement 
    page_versions.extend(self._package_versions(page.links, req.name.lower())) 
    File "c:\python27\lib\site-packages\pip\index.py", line 440, in _package_versions 
    for link in self._sort_links(links): 
    File "c:\python27\lib\site-packages\pip\index.py", line 430, in _sort_links 
    for link in links: 
    File "c:\python27\lib\site-packages\pip\index.py", line 772, in links 
    for anchor in self.parsed.findall(".//a"): 
TypeError: findall() takes exactly 2 arguments (3 given) 

我使用Windows 7 32位,Python 2.7版

+3

該異常與引用的源代碼行不匹配。完全一樣。你有沒有在編輯'pip'源文件? –

+1

我現在要做的是:從'c:\ python27 \ lib \ site-packages \'中刪除整個'pip'目錄並重新安裝。很可能,'.pyc'字節緩存文件是陳舊的,不再與'index.py'(可能還有其他文件)的源相匹配。 'parsed'對象只是一個'html5lib'分析樹,其中''html5lib'庫包含*'pip'庫源代碼樹。 –

+1

我重新安裝它,我得到了同樣的結果。我沒有編輯點子源 – user3203242

回答

1

我認爲你的ElementTree的版本有誤不知何故在pipself.parsed應該是一個html5lib解析樹。通過html5lib.parse作用於HTML的對象返回來自包的頁面。 readme for html5lib說:

默認情況下,文檔將是一個xml.etree元素實例。只要有可能,html5lib會選擇加速的ElementTree實現(即Python 2.x中的xml.etree.cElementTree)。

This question在不同的上下文中描述了類似的問題,並且隱藏在註釋中,我們看到OP通過不同地導入ElementTree來解決問題。我認爲你不知何故有一些不兼容的版本,可能是cElementTree,其中html5lib tries to use if it can

我會建議卸載elementtree(如果它存在於任何站點包目錄中,並且您沒有具體的原因)。如果這不起作用,則完全卸載/重新安裝pip似乎是最佳選擇。

測試的問題(答案不嚴格一部分)

你可以嘗試去一個命令提示符並試圖import xml.etreeimport elementtree。如果他們都工作分別嘗試help(xml.etree)help(elementtree)。檢查DESCRIPTION部分中給出的構建日期。如果你有一個非常陳舊的(2008年之前)elementtree構建,並沒有一個具體的原因,然後卸載它。

相關問題