Selenium-python 下载但文件保存为 .part

2024-01-01

我的脚本可以工作,但它将文件另存为 .part,尽管与手动下载的文件进行检查,其大小相同且幸运的是完整的。我不明白为什么它被保存为部分文件。对我的下一个想法有点不方便。有人知道为什么会这样吗?这是我的代码...它有效...

from selenium import webdriver
from selenium.common.exceptions import NoSuchElementException
from selenium.webdriver.common.keys import Keys
import time
import mechanize
import urllib
from urllib import urlretrieve

fp = webdriver.FirefoxProfile()

fp.set_preference("browser.download.folderList",1)
fp.set_preference("browser.download.manager.showWhenStarting",False)
fp.set_preference("browser.download.dir",'Users/matthewyoung/Downloads')
fp.set_preference("browser.helperApps.neverAsk.saveToDisk","Plain text")
fp.set_preference("browser.download.manager.scanWhenDone",False)
fp.set_preference("browser.download.manager.showAlertOnComplete",True)
fp.set_preference("browser.download.manager.useWindow",False)
fp.set_preference("browser.helperApps.alwaysAsk.force",False)

browser = webdriver.Firefox(firefox_profile=fp)



#browser = webdriver.Firefox() # Get local session of firefox
browser.get("http://vizier.u-strasbg.fr/vizier/surveys.htx") # Load page
assert "VizieR" in browser.title
#p = raw_input('Star name? ')
elem = browser.find_element_by_name('-c') # Find the query box
elem.send_keys('mwc 560' + Keys.RETURN)
time.sleep(0.2) # Let the page load, will be added to the API
elem=browser.find_element_by_name('-out.max')
elem.send_keys('unlimited'+Keys.TAB)
elem2=browser.find_element_by_name('-out.form')
time.sleep(0.5)
elem2.send_keys('; -Separated-Values')
time.sleep(0.5)
elem2.send_keys(Keys.TAB)
elem2.send_keys(Keys.TAB)
time.sleep(0.2)
browser.find_element_by_class_name('data').submit()
time.sleep(3.0)
#df=elem2.send_keys(Keys.SPACE)
#print df
browser.close()

它正在下载为 .part,因为出现了弹出的另存为对话框窗口。 Python无法处理弹出窗口。我发现,当您尝试在 webdriver 中设置自定义配置文件时,它不一定有效(例如,我能够在 selenium 中设置自定义配置文件来下载 csv,但不能下载 pdf)。但是,我能够通过在 Firefox 中创建自定义配置文件来解决我的 pdf 问题。我对 tsv 文件不太有经验,所以我不确定那是什么设置。如果您可以创建一个新的 Firefox 配置文件(按照此处的说明进行操作:https://support.mozilla.org/en-US/kb/profile-manager-create-and-remove-firefox-profiles https://support.mozilla.org/en-US/kb/profile-manager-create-and-remove-firefox-profiles) 您可以尝试将该配置文件设置为默认保存 tsv。如果您不知道要进入并更改“about:config”的确切设置,您可以尝试单击弹出窗口上的复选框以始终保存此类文件。

从那里您可以将您的配置文件设置为您创建的自定义配置文件,如下所示:

    profile = webdriver.firefox.firefox_profile.FirefoxProfile("/Users/matthewyoung/Library/Application Support/Firefox/Profiles/"YOUR PROFILE NAME")

请记住,您的个人资料名称首先将包含一堆随机字母,因此请按照该路径查找实际的个人资料名称。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Selenium-python 下载但文件保存为 .part 的相关文章

随机推荐