driver.get(URL),driver.navigate()。to(URL)和driver.navigate()。back()不起作用

时间:2020-05-19 02:41:34

标签: java selenium webdriver selenium-chromedriver

我正在尝试获取此亚马逊页面(https://www.amazon.com/s?rh=n%3A565108%2Cp_72%3A4-&pf_rd_i=565108&pf_rd_p=b2e34a42-7eb2-50c2-8561-292e13c797df&pf_rd_r=E87FK4Z32CV7VPR4EZGP&pf_rd_s=merchandised-search-11&pf_rd_t=BROWSE&ref=Oct_s9_apbd_otopr_hd_bw_b2N0e_S)中每台笔记本电脑列表的图像URL。

该方法应该单击每个出售的列表,使用driver.findElement(By.xpath(namesXpath))。getAttribute(“ src”)获取图像URL,并将其保存到URL列表中。 。但是,当我尝试让驱动程序返回包含所有笔记本电脑列表的页面,以便它可以继续通过for循环并获取其他列表的图像时,出现以下错误。我已经尝试过driver.get(URL),driver.navigate()。to(URL)和driver.navigate()。back(),但它们都无法将我带回到上一页。

奇怪的是,在我的主要方法中,driver.get(“ https://amazon.com”)可以正常工作,而driver.findElement(by.xpath).click()也可以正常工作。只是在这种方法破损的地方。

我是s = java和selenium的新手,所以我希望一切都说得通。任何帮助,将不胜感激。让我知道是否需要进一步澄清

Exception in thread "main" org.openqa.selenium.NoSuchElementException: no such element: Unable to locate element: {"method":"xpath","selector":"//img [@id="detailImg"]"}
  (Session info: chrome=81.0.4044.138)
For documentation on this error, please visit: https://www.seleniumhq.org/exceptions/no_such_element.html
Build info: version: '3.141.59', revision: 'e82be7d358', time: '2018-11-14T08:25:48'
System info: host: 'DESKTOP-AU2FJQL', ip: '192.168.0.245', os.name: 'Windows 10', os.arch: 'amd64', os.version: '10.0', java.version: '1.8.0_251'
Driver info: org.openqa.selenium.chrome.ChromeDriver
Capabilities {acceptInsecureCerts: false, browserName: chrome, browserVersion: 81.0.4044.138, chrome: {chromedriverVersion: 81.0.4044.69 (6813546031a4b..., userDataDir: C:\Users\email\AppData\Loca...}, goog:chromeOptions: {debuggerAddress: localhost:50907}, javascriptEnabled: true, networkConnectionEnabled: false, pageLoadStrategy: normal, platform: WINDOWS, platformName: WINDOWS, proxy: Proxy(), setWindowRect: true, strictFileInteractability: false, timeouts: {implicit: 0, pageLoad: 300000, script: 30000}, unhandledPromptBehavior: dismiss and notify, webauthn:virtualAuthenticators: true}
Session ID: 1fe48e105aae883db4215eba6bb8c06b
*** Element info: {Using=xpath, value=//img [@id="detailImg"]}
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
    at java.lang.reflect.Constructor.newInstance(Unknown Source)
    at org.openqa.selenium.remote.http.W3CHttpResponseCodec.createException(W3CHttpResponseCodec.java:187)
    at org.openqa.selenium.remote.http.W3CHttpResponseCodec.decode(W3CHttpResponseCodec.java:122)
    at org.openqa.selenium.remote.http.W3CHttpResponseCodec.decode(W3CHttpResponseCodec.java:49)
    at org.openqa.selenium.remote.HttpCommandExecutor.execute(HttpCommandExecutor.java:158)
    at org.openqa.selenium.remote.service.DriverCommandExecutor.execute(DriverCommandExecutor.java:83)
    at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:552)
    at org.openqa.selenium.remote.RemoteWebDriver.findElement(RemoteWebDriver.java:323)
    at org.openqa.selenium.remote.RemoteWebDriver.findElementByXPath(RemoteWebDriver.java:428)
    at org.openqa.selenium.By$ByXPath.findElement(By.java:353)
    at org.openqa.selenium.remote.RemoteWebDriver.findElement(RemoteWebDriver.java:315)
    at Executer.picsUpdateList(Executer.java:363)
    at Executer.main(Executer.java:163) 
public static String namesXpath = "//span[@data-a-strike=\"true\" or contains(@class,\"text-strike\")][.//text()]/preceding::span[@class][10]";

public static void picsUpdateList(WebDriver driver, List<String> URLs, List<BufferedImage> pics) throws IOException, InterruptedException
    {
        //list of deals on amazon page
        List<WebElement> deals = driver.findElements(By.xpath(namesXpath));

        //URL of each picture saved since this method was called
        List<String> freshURLs = new ArrayList<String>();

        //saves the URL of the page with all listings
        String pageURL = driver.getCurrentUrl();
        System.out.println(pageURL);

        //1. clicks on each deal from List<> deals
        //2. Grabs picture by xpath and saves the URL to both lists
        //3. 
        for(WebElement deal : deals)
        {
            deal.click();
            System.out.println("clicked on next deal");
            Thread.sleep(time);
            String url = driver.findElement(By.xpath("//img [@id=\"detailImg\"]")).getAttribute("src");
            URLs.add(url);
            freshURLs.add(url);
            System.out.println(url);
/// ERROR HERE//////////////////////////
            driver.navigate().back();
//////////////////////////////////////////
            System.out.println("back to page");
            Thread.sleep(time);
        }

        for(String url : freshURLs)
        {
            pics.add(ImageIO.read(new URL(url)));
        }

    }

1 个答案:

答案 0 :(得分:0)

我建议使用@id="landingImage"而不是@id="detailImg"。 然后获取data-old-hires字段值以获取URL。这与您从@id="detailImg"获取的源URL相同(但正如我之前的评论中所述,您可能需要先将鼠标悬停在屏幕上的图像上,然后弹出该元素,我认为这是错误的原因)。

您可以先尝试编写代码,然后告诉我们是否可以解决您的问题。

以下是交易示例,请点击您提供的亚马逊页面网址。 我用蓝色强调了上面提到的细节。 希望这可以解决您的问题。

enter image description here