国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python獲取當前頁面內所有鏈接的四種方法對比分析

2019-11-25 15:55:13
字體:
來源:轉載
供稿:網(wǎng)友

本文實例講述了Python獲取當前頁面內所有鏈接的四種方法。分享給大家供大家參考,具體如下:

'''得到當前頁面所有連接'''import requestsimport refrom bs4 import BeautifulSoupfrom lxml import etreefrom selenium import webdriverurl = 'http://www.testweb.com'r = requests.get(url)r.encoding = 'gb2312'# 利用 re (太黃太暴力!)matchs = re.findall(r"(?<=href=/").+?(?=/")|(?<=href=/').+?(?=/')" , r.text)for link in matchs:  print(link)print()# 利用 BeautifulSoup4 (DOM樹)soup = BeautifulSoup(r.text,'lxml')for a in soup.find_all('a'):  link = a['href']  print(link)print()# 利用 lxml.etree (XPath)tree = etree.HTML(r.text)for link in tree.xpath("http://@href"):  print(link)print()# 利用selenium(要開瀏覽器!)driver = webdriver.Firefox()driver.get(url)for link in driver.find_elements_by_tag_name("a"):  print(link.get_attribute("href"))driver.close()

注意:若頁面中含有 iframe,則 iframe 內所包含頁面的所有標簽都無法用以上四種方法獲得!!!此時則要:

# 再打開所有iframe查找全部的a標簽for iframe in soup.find_all('iframe'):  url_ifr = iframe['src'] # 取得當前iframe的src屬性值   rr = requests.get(url_ifr)  rr.encoding = 'gb2312'  soup_ifr = BeautifulSoup(rr.text,'lxml')  for a in soup_ifr.find_all('a'):    link = a['href']    m = re.match(r'http:////.*?(?=//)',link)    #print(link)    if m:      all_urls.add(m.group(0))

PS:這里再為大家提供2款非常方便的正則表達式工具供大家參考使用:

JavaScript正則表達式在線測試工具:
http://tools.VeVB.COm/regex/javascript

正則表達式在線生成工具:
http://tools.VeVB.COm/regex/create_reg

更多關于Python相關內容可查看本站專題:《Python正則表達式用法總結》、《Python數(shù)據(jù)結構與算法教程》、《Python函數(shù)使用技巧總結》、《Python字符串操作技巧匯總》、《Python入門與進階經(jīng)典教程》及《Python文件與目錄操作技巧匯總

希望本文所述對大家Python程序設計有所幫助。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 上犹县| 泗洪县| 汉源县| 乐昌市| 靖州| 玉林市| 政和县| 饶平县| 遂昌县| 共和县| 隆林| 闽清县| 淅川县| 龙山县| 临桂县| 铜梁县| 江华| 称多县| 定南县| 宣武区| 察雅县| 沅陵县| 高邮市| 宝应县| 大冶市| 喀什市| 泰州市| 浙江省| 齐河县| 楚雄市| 日喀则市| 广饶县| 大姚县| 冕宁县| 米林县| 兴城市| 新绛县| 昌邑市| 兴山县| 鹿邑县| 疏附县|