方法一:
<code class="language-python">""" 根據table的id屬性和table中的某一個元素定位其在table中的位置 table包括表頭,位置坐標都是從1開始算 tableId:table的id屬性 queryContent:需要確定位置的內容 """ def get_table_content(tableId,queryContent): arr = [] arr1 = [] table_loc = (By.ID,tableId) # 按行查詢表格的數據,取出的數據是一整行,按空格分隔每一列的數據 table_tr_list = driver.find_element(*table_loc).find_elements(By.TAG_NAME, "tr") for tr in table_tr_list: arr1 = (tr.text).split(" ") #以空格拆分成若干個(個數與列的個數相同)一維列表 # print(tr.text) # print(arr1) arr.append(arr1) #將表格數據組成二維的列表 #循環遍歷table數據,確定查詢數據的位置 for i in range(len(arr)): for j in range(len(arr[i])): if queryContent== arr[i][j]: print("%r坐標為(%r,%r)" %(queryContent,i+1,j+1)) get_table_content("myTable","第二行第二列")</code>
方法二:
"""根據table的id屬性和table中的某一個元素定位其在table中的位置table包括表頭,位置坐標都是從1開始算tableId:table的id屬性queryContent:需要確定位置的內容"""def get_table_content(tableId,queryContent): # 按行查詢表格的數據,取出的數據是一整行,按空格分隔每一列的數據 table_tr_list = driver.find_element(By.ID, tableId).find_elements(By.TAG_NAME, "tr") table_list = [] #存放table數據 for tr in table_tr_list: #遍歷每一個tr #將每一個tr的數據根據td查詢出來,返回結果為list對象 table_td_list = tr.find_elements(By.TAG_NAME, "td") row_list = [] print(table_td_list) for td in table_td_list: #遍歷每一個td row_list.append(td.text) #取出表格的數據,并放入行列表里 table_list.append(row_list) # 循環遍歷table數據,確定查詢數據的位置 for i in range(len(table_list)): for j in range(len(table_list[i])): if queryContent== table_list[i][j]: print("%r坐標為(%r,%r)" %(queryContent,i+1,j+1)) get_table_content("myTable","第二行第二列")
方法三:
"""根據CSS選擇器和table中的某一個元素定位其在table中的位置table包括表頭,位置坐標都是從1開始算cssSelector:table的CSS選擇器屬性queryContent:需要確定位置的內容"""def get_table_content(cssSelector,queryContent): locator = cssSelector + ">tbody>tr" table_list = [] table_tr_list = driver.find_elements(By.CSS_SELECTOR, locator)[1:] #去掉表頭 for tr in table_tr_list: row_list = [] table_td_list = tr.find_elements(By.TAG_NAME,"td") for td in table_td_list: row_list.append(td.text) table_list.append(row_list) for i in range(len(table_list)): for j in range(len(table_list[i])): if queryContent== table_list[i][j]: print("%r坐標為(%r,%r)" %(queryContent,i+1,j+1)) get_table_content("#myTable","第二行第二列")
新聞熱點
疑難解答