无法选中复选框

时间:2019-07-12 10:21:40

标签: python selenium

我正在尝试选中该复选框,但出现以下错误

selenium.common.exceptions.NoSuchElementException: Message: no such 
element: Unable to locate element: {"method":"xpath","selector":"//mat- 
checkbox[@id='mat-checkbox-1']/label/div"}

我尝试使用id,css-selector和xpath进行选择,但一直出错。

reg_date_checkbox = self.browser.find_element_by_xpath("//matcheckbox[@id='mat-checkbox-1']/label/div")
reg_date_checkbox.location_once_scrolled_into_view
reg_date_checkbox.click()

复选框的HTML是

<div _ngcontent-fep-c23="" class="last-date my-12 ng-star-inserted" fxlayout="column" style="flex-direction: column; box-sizing: border-box; display: flex;">
<mat-checkbox _ngcontent-fep-c23="" class="mat-checkbox mat-accent ng-untouched ng-pristine ng-valid" formcontrolname="deadline_enabled" id="mat-checkbox-1">
    <label class="mat-checkbox-layout" for="mat-checkbox-1-input">
        <div class="mat-checkbox-inner-container">
            <input class="mat-checkbox-input cdk-visually-hidden" type="checkbox" id="mat-checkbox-1-input" tabindex="0" aria-checked="false">
            <div class="mat-checkbox-ripple mat-ripple" matripple="">
                <div class="mat-ripple-element mat-checkbox-persistent-ripple"></div>
            </div>
            <div class="mat-checkbox-frame"></div>
            <div class="mat-checkbox-background">
                <svg xml:space="preserve" class="mat-checkbox-checkmark" focusable="false" version="1.1" viewBox="0 0 24 24">
                    <path class="mat-checkbox-checkmark-path" d="M4.1,12.7 9,17.6 20.3,6.3" fill="none" stroke="white"></path>
                </svg>
                <div class="mat-checkbox-mixedmark"></div>
            </div>
        </div><span class="mat-checkbox-label"><span style="display:none">&nbsp;</span>The event has a registration deadline</span>
    </label>
</mat-checkbox>
<!---->

3 个答案:

答案 0 :(得分:0)

您正在使用此xpath //matcheckbox[@id='mat-checkbox-1']/label/div,应该是//mat-checkbox[@id='mat-checkbox-1']/label/div,中间有一个-,您会丢失它。

仍然可以使用此 css选择器

div.mat-checkbox-inner-container input[class^='mat-checkbox-input'][id^='mat-checkbox']

复选框可能存在于iframe中,如果是这种情况,请先切换到框架,然后尝试单击复选框。

答案 1 :(得分:0)

您可以尝试以下方法:

element = self.browser.find_element_by_css("input#mat-checkbox-1-input")
element.click()

答案 2 :(得分:0)

您可能正在尝试单击非“复选框”类型的元素。我看到有一个带有类型复选框的输入。请尝试下面提到的代码

reg_date_checkbox = self.browser.find_element_by_xpath("//input[@id='mat-checkbox-1-input']")
reg_date_checkbox.click()

另外,如果您希望执行取消选中操作,则可以在执行单击之前查找输入元素的aria-checked属性为true。