亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

元素在檢查模式下具有 ID,但在原始 HTML 中沒有 ID

元素在檢查模式下具有 ID,但在原始 HTML 中沒有 ID

倚天杖 2022-08-16 16:17:21
我目前正在使用Python和Selenium開發一個小的Web抓取腳本。我正在嘗試從表中獲取一些信息,該表在檢查模式下具有某個ID。但是,當我以原始HTML的形式打開頁面時(我在無法使用xpath或css_selector找到該表之后),該表沒有提到的ID。這怎么可能?為了更好的解釋:這就是我在瀏覽器中的檢查模式下的樣子<table id='ext-gen1076' class='bats-table bats-table--center'>[...]</table>這就是我作為原始HTML文件打開頁面時的樣子<table class='bats-table bats-table--center'>[...]</table>ID怎么可能消失?(JFI,這是我的第一個問題,所以對格式不好表示歉意!提前致謝!
查看完整描述

2 回答

?
蠱毒傳說

TA貢獻1895條經驗 獲得超3個贊

原因是,ID 是在運行時添加的。


查看完整回答
反對 回復 2022-08-16
?
Smart貓小萌

TA貢獻1911條經驗 獲得超7個贊

id屬性的值,即ext-gen1076包含一個數字,并且顯然是動態生成的。id 屬性值的前綴,即 ext-gen 表示 id 是使用 Ext JS 在運行時生成的。


分機 JS

Ext JS是一個JavaScript框架,用于為任何現代設備構建數據密集型,跨平臺的Web和移動應用程序。


此用例

可能你甚至在 JavaScript 呈現完整的 DOM 樹之前就已經識別了該元素。因此缺少 id 屬性。<table>


識別 Ext JS 元素

隨著id屬性的值發生變化,即本質上是動態的,您將無法使用id屬性的完整值,并且只能使用靜態的部分值。根據您提供的 HTML:


<table id='ext-gen1076' class='bats-table bats-table--center'>

[...]

</table>

要識別<>節點,您需要誘導 WebDriverWait,并且可以使用以下任一定位器策略:tablevisibility_of_element_located()


用:CSS_SELECTOR


WebDriverWait(driver, 20).until(EC.visibility_of_element_located((By.CSS_SELECTOR, "table[id^='ext-gen']")))

用:XPATH


WebDriverWait(driver, 20).until(EC.visibility_of_element_located((By.XPATH, "//table[starts-with(@id,'ext-gen')]")))

注意:您必須添加以下導入:


from selenium.webdriver.support.ui import WebDriverWait

from selenium.webdriver.common.by import By

from selenium.webdriver.support import expected_conditions as EC

但是,還有很多其他元素的id屬性以ext-gen開頭。因此,要唯一標識元素,您需要按如下方式組合 class 屬性:<table>


用:CSS_SELECTOR


WebDriverWait(driver, 20).until(EC.visibility_of_element_located((By.CSS_SELECTOR, "table.bats-table.bats-table--center[id^='ext-gen']")))

用:XPATH


WebDriverWait(driver, 20).until(EC.visibility_of_element_located((By.XPATH, "//table[@class='bats-table bats-table--center' and starts-with(@id,'ext-gen')]")))


查看完整回答
反對 回復 2022-08-16
  • 2 回答
  • 0 關注
  • 98 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號