[英]How to get dynamic elements in this case using Selenium/Python?
我嘗試在頁面加載后獲取動態加載到頁面的元素。
這是 html,不包括 html 和之前的其他一些 div 中的最后一個腳本。 type="report" 的 comment-div 被動態加載到頁面中。 我認為該網站使用 Angular 或其他東西。
<div class="sc-fUKshf bNdPM">
<div data-testid="comment" type="report" class="sc-cTmXAz cwRvCX">
<div class="sc-bCwfaz sc-QfGIp gDveND hNwnuN">
<div class="sc-hepHJq gyIWHj">
<svg width="28" height="27" viewBox="0 0 28 27" xmlns="http://www.w3.org/2000/svg" data-testid="report">
<g transform="translate(.5)" fill="none" fill-rule="evenodd">
<rect fill="#E3DFF2" width="27" height="27" rx="10.916"></rect>
<path d="M16.009 10.89h-.602a2.73 2.73 0 00-2.723 2.916c.077 1.119.132 1.821.167 2.107.039.327.169 1.096.389 2.31a2.205 2.205 0 002.452 1.792 2.713 2.713 0 002.341-2.328c.128-.951.215-1.543.259-1.774.037-.194.162-.754.376-1.68a2.73 2.73 0 00-2.66-3.343zm6.038 4.327l-.343-.1a1.662 1.662 0 00-2.129 1.598c.001.322.003.52.007.595.005.106.037.398.093.877a1.36 1.36 0 001.515 1.192c.828-.1 1.53-.655 1.82-1.437l.172-.465a1.73 1.73 0 00-1.135-2.26zM7.453 6.436l-.565.057a3.411 3.411 0 00-3.038 3.842c.345 2.597.606 4.268.785 5.014.19.79.641 2.285 1.353 4.485a3.063 3.063 0 003.13 2.112 2.29 2.29 0 002.114-2.53c-.265-2.443-.409-4.119-.432-5.028-.02-.767.072-2.217.276-4.35a3.305 3.305 0 00-3.623-3.602z" fill="#8F7FCE"></path>
</g>
</svg>
<div data-testid="activity-title" class="sc-dmiYbj bEyWbu"><span class="sc-jVBfSZ keEVDi">Weekly report</span></div>
</div>
<div class="sc-bCwfaz sc-jomqko hGiREx gbkTPQ">
<div class="sc-bXXDC jSxSkF">28 May 2021</div>
</div>
</div>
Some text
<div data-testid="comment-reply-button" class="sc-clYhRO dZSmwI">
<svg data-name="Layer 1" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 21 21.97" width="21" height="22" class="sc-fdnhOL dYoRsn">
<path d="M19.03 8.35v10.81a1.81 1.81 0 01-1.8 1.81H2.81A1.81 1.81 0 011 19.16V4.74a1.8 1.8 0 011.81-1.8h9" fill="none" stroke="#384a5f" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2"></path>
<path d="M19.64 3.58a1.57 1.57 0 10-2.41-2l-7.21 7.67v2.7l2.7-.9z" fill="none" stroke="#384a5f" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2"></path>
</svg>
Text
</div>
<div class="sc-iArHnM eEOXNH">
<form data-testid="reply-form">
<div class="sc-jfkLlK fHByXR"><textarea data-testid="text-area" placeholder="Text" name="replyMessage" id="replyMessage" rows="3" height="auto" class="sc-fcmMJX ldYVmw"></textarea></div>
<div class="sc-bHCRaJ gPCKhJ"><button data-testid="comment-reply-cancel-button" type="button" class="sc-ckTSus sc-fzJAIQ kiNKGC irzfTA">Text</button><button data-testid="comment-reply-submit-button" type="submit" class="sc-lbVvki hxgvIg">Text</button></div>
</form>
</div>
</div>
</div>
這是 python/selenium 代碼:
relativeXpathToReportComments = "//div[@type='report']"
try:
time.sleep(5) #explicit wait in seconds.
element = WebDriverWait(driver, 90).until(EC.element_to_be_clickable((By.XPATH, relativeXpathToReportComments))) #does not always work?
comments = driver.find_elements_by_xpath(relativeXpathToReportComments) #list all elements with comments with type Report
print("You found the elements for comments:" + comments)
length = len(comments)
print (length)
commentReport = comments[0].get_attribute("innerText").split('\n')[2] #get all the strings inside the element from the first/latest report, in a list with split, then extract only the right comment string (not the title, date etc)
print("Your last report was:" + commentReport)
except:
print("could not find/get comments on comment page")
90% 的時間我得到“無法在評論頁面上找到/獲得評論”的結果。 它永遠不會在代碼的第一次運行中運行,但是當我再次調用 function 時,它會在 5-10% 的時間內運行上面的代碼。
我猜"//div[@type='report']"
定位器不是唯一的,因此 Selenium 以預期條件捕獲了其他一些元素,而該元素不可點擊。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.