我有一个 Python 网络抓取程序,它从给定站点获取所有链接,然后我设法打印出每个链接的域名和路径。
编码:
import urllib
import re
import mechanize
from bs4 import BeautifulSoup
import urlparse
import cookielib
url = "http://www.sparkbrowser.com"
br = mechanize.Browser()
cj = cookielib.LWPCookieJar()
br.set_cookiejar(cj)
br.set_handle_robots(False)
br.set_handle_equiv(False)
br.set_handle_redirect(True)
br.set_handle_refresh(mechanize._http.HTTPRefreshProcessor(), max_time=1)
br.addheaders = [('User-agent', 'Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.0.1) Gecko/2008071615 Fedora/3.0.1-1.fc9 Firefox/3.0.1')]
page = br.open(url, timeout=5)
htmlcontent = page.read()
soup = BeautifulSoup(htmlcontent)
for link in br.links(text_regex=re.compile('^((?!IMG).)*$')):
newurl = urlparse.urljoin(link.base_url, link.url)
base = link.base_url
print base," - ",newurl
它让我得到这样的结果:
http://www.sparkbrowser.com - http://www.sparkbrowser.com
http://www.sparkbrowser.com - http://sparkbrowser.com
http://www.sparkbrowser.com - http://www.sparkbrowser.com/index.php
http://www.sparkbrowser.com - http://www.sparkbrowser.com/download.php
http://www.sparkbrowser.com - http://www.sparkbrowser.com/about.php
http://www.sparkbrowser.com - http://www.sparkbrowser.com/features.php
http://www.sparkbrowser.com - http://www.sparkbrowser.com/spark.php
etc....
我想知道如何仅sparkbrowser.com
或sparkbrowser
仅从给定地址获取?
我知道如何分隔域名http://www.sparkbrowser.com
和路径,但我不知道是否可以打印我提到的部分 URL
我用 Regex 尝试了一些东西,但我没有成功。
欢迎任何帮助。