![](/img/trans.png)
[英]Python AttributeError: NoneType object has no attribute 'close'
[英]AttributeError: 'NoneType' object has no attribute 'close'
我是python js的新手,我正在尝试运行github上可用的项目
但是当我尝试运行时会出现以下错误
Traceback (most recent call last): File "main.py", line 81, in
<module>
crawler_machine() File "main.py", line 76, in crawler_machine
driver.close() AttributeError: 'NoneType' object has no attribute 'close'
Exception AttributeError: "'Service' object has no attribute
'process'" in <bound method Service.__del__ of
<selenium.webdriver.phantomjs.service.Service object at 0x107d05790>>
ignored
我遵循该项目中给出的所有指示
代码是main.py
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from config import URL_FORMAT, SCROLL_TIMES, PHANTOM_JS_PATH, WEBDRIVER
from parser import FParser
from optparse import OptionParser
import signal
import sys
import time
driver = None
def close(signal, frame):
'''
When you press Ctrl-C the browser closes
'''
global driver
print('You pressed Ctrl+C!')
driver.close()
signal.pause()
sys.exit(0)
def scroll_down(driver):
'''
This helps you to scroll the search results page to load more results
'''
for i in range(SCROLL_TIMES):
driver.execute_script("window.scrollTo(0, document.body.scrollHeight);")
time.sleep(0.3)
def get_page(driver, url):
driver.get(url)
return driver.page_source
def press_the_button_2_crawl(driver, keyword):
"""
Main function handles everything
"""
html_data = get_page(driver, URL_FORMAT % keyword)
scroll_down(driver)
parser = FParser(html_data)
parser.store() #store into db
time.sleep(2)
def crawler_machine(search_word=None):
global driver
optparser = OptionParser()
optparser.add_option("-s", "--search",
type="string", dest="search")
(options, args) = optparser.parse_args()
keyword = options.search or search_word
print "Keyword",keyword
try:
try:
#headless phantomjs for 32bit unix based machines
driver = webdriver.PhantomJS(executable_path=PHANTOM_JS_PATH)
except:
#firefox
driver = webdriver.Firefox()
signal.signal(signal.SIGINT, close)
press_the_button_2_crawl(driver, keyword)
finally:
driver.close() #line 76=================================
if __name__ == '__main__':
crawler_machine() #line 81=================================
我的猜测是创建驱动程序的两种尝试-PhantomJS和FireFox-均失败,这意味着当您到达finally块时,该driver
仍然为None
。 您可以通过添加显式检查来确认这一点:
finally:
if driver:
driver.close()
else:
print "Could not create driver"
关于为什么驱动程序创建失败的原因,最可能的解释是安装问题。 您可以通过在Python环境中运行一个简单的示例来对此进行测试:
>>> from selenium.webdriver import Firefox
>>> d = Firefox()
>>> d.get('http://stackoverflow.com')
如果这不能打开Firefox并导航到Stack Overflow的首页,请查看您的OS的Selenium文档。
如果PhantomJS
和Firefox
的创建均失败,则不会初始化driver
。
关闭前添加支票:
if driver:
driver.close()
如果try ... except子句都在crawler_machine中都失败,则驱动程序的全局值将为None。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.