<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                [TOC] ## 一、十八種定位方法 前八種是大家都熟悉的,經常會用到的 ``` 1.id定位:find_element_by_id(self, id_) 2.name定位:find_element_by_name(self, name) 3.class定位:find_element_by_class_name(self, name) 4.tag定位:find_element_by_tag_name(self, name) 5.link定位:find_element_by_link_text(self, link_text) 6.partial_link定位find_element_by_partial_link_text(self, link_text) 7.xpath定位:find_element_by_xpath(self, xpath) 8.css定位:find_element_by_css_selector(self, css_selector) ``` <br /> 這八種是復數形式 ``` 9.id復數定位find_elements_by_id(self, id_) 10.name復數定位find_elements_by_name(self, name) 11.class復數定位find_elements_by_class_name(self, name) 12.tag復數定位find_elements_by_tag_name(self, name) 13.link復數定位find_elements_by_link_text(self, text) 14.partial_link復數定位find_elements_by_partial_link_text(self, link_text) 15.xpath復數定位find_elements_by_xpath(self, xpath) 16.css復數定位find_elements_by_css_selector(self, css_selector ``` <br /> 這兩種就是快失傳了的 ``` find_element(self, by='id', value=None) find_elements(self, by='id', value=None) ``` <br /> ## 二、element和elements傻傻分不清 1. element方法定位到是是單數,是直接定位到元素 2. elements方法是復數,定位到的是一組元素,返回的是list隊列 3. 可以用type()函數查看數據類型 4. 打印這個返回的內容看看有什么不一樣 ![Snipaste_2020-08-21_14-14-17.png](https://i.loli.net/2020/08/21/4NCmO68Ac7lqFVx.png) <br /> ## 三、elements定位方法 1. 前面一篇已經講過find\_element()的用法,看這里: 2. 這里重點介紹下用elements方法如何定位元素,當一個頁面上有多個屬性相同的元素時,然后父元素的屬性也比較模糊,不太好定位。 這個時候不用怕,換個思維,別老想著一次定位到,可以先把相同屬性的元素找出來,取對應的第幾個就可以了。 3. 如下圖,百度頁面上有六個class一樣的元素,我要定位“地圖”這個元素 ![Snipaste_2020-08-21_14-21-57.png](https://i.loli.net/2020/08/21/AlIkG4B2uf5HCqS.png) 4. 取對應下標即可定位了 ![Snipaste_2020-08-21_14-24-33.png](https://i.loli.net/2020/08/21/tbs8Nm2vuV7lH5E.png) <br /> ## 四、參考代碼 ``` # coding:utf-8 from selenium import webdriver driver = webdriver.Chrome() driver.get("http://www.baidu.com") # 這里用的css語法 elements = driver.find_elements("css selector", ".mnav") # '地圖'在第三個位置 print(elements[2].text) elements[2].click() # 這個寫法也是可以的 driver.find_elements("css selector", ".mnav")[2].click() ```
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看