如何使用selenium python点击google上的第一个结果

Ven*_*raj 3 python selenium selenium-webdriver

我试图点击谷歌搜索结果的第一个结果.这是我的代码,我进入chennai craiglist,从csv文件中读取.所以我相信有机结果中的第一个链接将是chennai.craiglist.org.但我很安静,不知道如何做到这一点.

from selenium import webdriver
    from selenium.webdriver.common.by import By
    from selenium.webdriver.support.ui import Select
    from selenium.common.exceptions import NoSuchElementException
    import unittest, time, re

    class Browse(unittest.TestCase):
    def setUp(self):
    self.driver = webdriver.Firefox()
    self.driver.implicitly_wait(30)
    self.base_url = "http://google.com/"

    filename = 'test.csv'
    line_number = 1
    with open(filename, 'rb') as f:
        mycsv = csv.reader(f)
        mycsv = list(mycsv)
        self.cityname=mycsv[line_number][0]
        self.username=mycsv[line_number][1]
        self.password=mycsv[line_number][2]
        self.verificationErrors = []

def test_browse(self):
    driver = self.driver
    driver.get(self.base_url + "/")
    driver.find_element_by_id("gbqfq").send_keys(self.cityname)
Run Code Online (Sandbox Code Playgroud)

我想知道这条线后会发生什么?

UPDATE

现在我给的是

driver.find_elements_by_xpath(".//*[@id='rso']//div//h3/a")[:1].click()
Run Code Online (Sandbox Code Playgroud)

我不确定它是否会起作用.

Mar*_*nds 5

xpath你选择的是"OK",但可能不是最好的.

result = driver.find_elements_by_xpath("//ol[@id="rso"]/li")[0] //make a list of results and get the first one
result.find_element_by_xpath("./div/h3/a").click() //click its href
Run Code Online (Sandbox Code Playgroud)