這兩天要在阿里雲日誌中操做UI,以輸入關鍵字搜索日誌。javascript
在send_keys時報錯element not interactable。html
第一個問題是iframe,經過切換iframe解決:java
driver.switch_to.frame(0) # 索引從0開始
第二個問題是span。python
F12查看html長這樣:react
①find_element(pre).click 有效,說明iframe切換成功了chrome
②find_element(span2).send_keys報錯後端
element not interactable
span不支持send_keys。dom
第一個方法,經過調js來解決,設置span的innerText阿里雲
search_text = 'error' log_search_span = driver.find_element_by_xpath( '//*[@id="queryEl"]/div[2]/div/div[6]/div[1]/div/div/div/div[5]/div/pre') js = 'arguments[0].innerText=arguments[1];' driver.execute_script(js, log_search_span, search_text)
第二個方法,添加屬性contenteditable加密
search_text = 'error' log_search_span = driver.find_element_by_xpath( '//*[@id="queryEl"]/div[2]/div/div[6]/div[1]/div/div/div/div[5]/div/pre') js = 'arguments[0].setAttribute("contenteditable", "true");' driver.execute_script(js, log_search_span) log_search_span.send_keys(search_text) # 可編輯後send_keys成功
雖然值設置成功了,可是不能用,在查詢時,仍是用空值在查詢。
通過分析,得出如下線索:
網上不少的方案是<input>標籤,比較好解決,阿里的這個span還真有點不簡單。
最後分享一下chrome console調試js的方法。
F12後,在元素上右鍵,選擇Copy selector,複製selector
切換到console,輸入便可定位到該元素:
document.querySelector('#queryEl > div.react-codemirror2 > div > div.CodeMirror-scroll > div.CodeMirror-sizer > div > div > div > div.CodeMirror-code > div > pre > span > span').innerText;