python+selenium對table表和分頁處理
更新時間:2022年01月26日 17:12:01 作者:bulabula2022??
這篇文章主要介紹了python+selenium對table表和分頁處理,文章內(nèi)容只要包括bulabula2022、table表分頁處理、網(wǎng)頁table所有內(nèi)容循環(huán)處理等相關(guān)內(nèi)容,需要的小伙伴可以參考一下
python+selenium編寫實現(xiàn)爬蟲過程:
- 1.爬蟲循環(huán)處理table表,
- 2.table表分頁處理,
- 3.網(wǎng)頁table所有內(nèi)容循環(huán)處理
- 4.獲取隱藏的href超鏈接內(nèi)容,
- 5.所有數(shù)據(jù)本地csv保存,
代碼如下:
from selenium.webdriver.chrome.options import Options import pandas as pd import math from selenium import webdriver import time
# 配置chrome的參數(shù)
options = Options()
options.add_argument('--headless')
# options.add_experimental_option('excludeSwitches', ['enable-automation']) #避開驗證碼
# 獲取一個瀏覽器對象
browser = webdriver.Chrome(chrome_options=options)
browser.get("C:\\Users\\XXXX\\XXXX.html")
# 打印整個表格信息
# print(browser.find_element_by_xpath("http://*[@id=\"versions-bom-layout\"]/div/div[5]/div/div/div/div[1]/table/tbody").text)
?
?
data = [] ?# 建立空列表存儲表格信息
# 獲取總頁數(shù)(通過二次定位方法進行定位)
# total_pages1 = len(browser.find_element_by_class_name("pagination").find_elements_by_tag_name("li")) - 2
# print("total_pages is %s" % (total_pages1))
?
# 共有多少個組件需要提取
total_num = \
? ? browser.find_element_by_xpath("http://*[@id=\"versions-bom-layout\"]/div/div[5]/div/div/div/div[1]/div").text.split(
? ? ? ? '共')[1]
print(f'total_num====::::::::{total_num}')
?
total_pages = math.ceil(int(total_num) / 100) + 1 ?# 每頁顯示100個組件, 獲取總頁數(shù)
print(f'total_pages====::::::::{total_pages}')
time.sleep(10) ?#
?
# total_pages = len(browser.find_element_by_tag_name('select').find_element_by_tag_name('option'))
for i in range(1, total_pages): ?# page:總共有total_pages-1頁
? ? # # 獲取分頁輸入框標簽的定位
? ? # inputpage = browser.find_element_by_xpath("http://*[@id='pager_center']/table/tbody/tr/td[5]/input")
? ? # # 首先清除輸入框里面的數(shù)字
? ? # inputpage.clear()
? ? # # 然后發(fā)送頁碼,我們?yōu)榱朔奖?,就把第一頁也寫在了里?
? ? # inputpage.send_keys(str(i))
? ? # # 最后模擬鍵盤點擊Enter鍵
? ? # inputpage.send_keys(Keys.ENTER)
? ? # # 為了是數(shù)據(jù)刷新出來,做了一個小小的死延時處理
?
? ? time.sleep(10) ?# 讓瀏覽器先加載一下動態(tài)頁面
? ? t_body = browser.find_element_by_tag_name('tbody') ?# 定位表格主體
? ? tr_list = t_body.find_elements_by_tag_name('tr') ?# 定位表格每一行
? ? numbers = len(tr_list)
? ? print(f'tr_list[0].text===={tr_list[0].text}')
?
? ? # for i in range(numbers):
? ? for tr in tr_list:
? ? ? ? td_list = tr.find_elements_by_tag_name('td') ?# 定位表格每個單元格
? ? ? ? lst = [] ?# 建立空列表存儲每行信息
? ? ? ? for td in td_list:
? ? ? ? ? ? # lst.append("B-momv2core-121-anyreport-BinaryScan") ?# 添加版本信息
? ? ? ? ? ? lst.append(td.text) ?# 添加每個單元格的文本信息
? ? ? ? ? ? href = td_list[4].find_element_by_tag_name('a').get_attribute("href") ?# 獲當前行第5個td單元格的超鏈接
? ? ? ? print(u"第n行第n列的text:", href)
? ? ? ? lst.append(href) ?# print(u"第一行第二列的text:", href) ?# 添加文件鏈接
? ? ? ? data.append(lst) ?# 添加每行信息
?
? ? # 點擊下一頁邏輯判斷
? ? # 如果table只有1頁,不作處理,直接退出循環(huán)
? ? # 如果table只有2頁,點擊下一頁處理條件(total_pages == 3 and i == 1)
? ? # 如果table2頁以上,點擊下一頁處理條件(total_pages > 3 and i < (total_pages - 1))
? ? if total_pages == 3 and i == 1:
? ? ? ? browser.find_element_by_xpath("http://*[contains(text(),'下一頁')]").click()
?
? ? elif total_pages > 3 and i < (total_pages - 1):
? ? ? ? browser.find_element_by_xpath("http://*[contains(text(),'下一頁')]").click()
?
df = pd.DataFrame(data,
? ? ? ? ? ? ? ? ? columns=['選擇', '策略', '審核', '版本組', '匹配數(shù)', '3', '4', '5', '6', '7', '8', '9', '10', '來源鏈接'])
df.to_csv('獲取未知xxx.csv', encoding='utf_8_sig')
browser.quit()效果圖:

到此這篇關(guān)于python+selenium對table表和分頁處理的文章就介紹到這了,更多相關(guān)python+selenium table表,分頁處理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python二維鍵值數(shù)組生成轉(zhuǎn)json的例子
今天小編就為大家分享一篇python二維鍵值數(shù)組生成轉(zhuǎn)json的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12
Python自然語言處理 NLTK 庫用法入門教程【經(jīng)典】
這篇文章主要介紹了Python自然語言處理 NLTK 庫用法,結(jié)合實例形式詳細分析了NLTK庫的功能、安裝、引用以及使用NLTK庫進行文本分析的各種常用操作技巧,需要的朋友可以參考下2018-06-06
Python趣味挑戰(zhàn)之turtle庫繪畫飄落的銀杏樹
銀杏還是和恐龍同時代的植物,被稱為活化石,適應(yīng)能力強,生長期漫長,壽命可達千年.因此,銀杏是長壽的代表和象征,接下來用Python的turtle庫來繪畫銀杏樹唯美的一幕,需要的朋友可以參考下2021-05-05

