Rumah > pembangunan bahagian belakang > Tutorial Python > Bagaimana untuk Mengklik Butang dengan Struktur HTML Kompleks Menggunakan Python Selenium?

Bagaimana untuk Mengklik Butang dengan Struktur HTML Kompleks Menggunakan Python Selenium?

Patricia Arquette
Lepaskan: 2024-10-22 15:58:03
asal
874 orang telah melayarinya

How to Click Buttons with Complex HTML Structure Using Python Selenium?

Python Selenium: Mengklik Butang dengan Struktur HTML Kompleks

Dalam pertemuan anda dengan Python Selenium, anda sedang mencari kaedah untuk mengklik butang dengan struktur HTML berikut:

<code class="html"><div class="b_div">
    <div class="button c_button s_button" onclick="submitForm('mTF')">
        <input class="very_small" type="button">
        <div class="s_image"></div>
        <span>
           Search
        </span>
    </div>
    <div class="button c_button s_button" onclick="submitForm('rMTF')" style="margin-bottom: 30px;">
        <input class="v_small" type="button">
        <span>
              Reset
        </span>
   </div>
</div></code>
Salin selepas log masuk

Walaupun cuba menggunakan pelbagai pemilih CSS seperti:

driver.find_element_by_css_selector('.button .c_button .s_button').click()
driver.find_element_by_name('s_image').click()
driver.find_element_by_class_name('s_image').click()
Salin selepas log masuk

Anda telah menemui NoSuchElementException. Untuk menangani cabaran ini, anda tertarik dengan kemungkinan memanfaatkan atribut onclick bagi elemen HTML.

Penyelesaian terletak pada pemilih CSS yang anda gunakan. Untuk berjaya mengklik butang, anda perlu mengalih keluar ruang antara kelas dalam pemilih anda. Berikut ialah versi yang diperbetulkan:

driver.find_element_by_css_selector('.button.c_button.s_button').click()
Salin selepas log masuk

Dengan mengalih keluar ruang antara kelas, Selenium akan mengenal pasti dan mengklik butang yang dikehendaki dengan tepat.

Atas ialah kandungan terperinci Bagaimana untuk Mengklik Butang dengan Struktur HTML Kompleks Menggunakan Python Selenium?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan