-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy path10.py
More file actions
68 lines (59 loc) · 2.34 KB
/
Copy path10.py
File metadata and controls
68 lines (59 loc) · 2.34 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
from urllib.request import urlopen
from bs4 import BeautifulSoup
import re
import datetime
import random
pages=set()
random.seed(datetime.datetime.now())
#获取页面所有內链的列表
def getInternalLinks(bsObj,includeUrl):
internalLinks = []
#找出所有以/开头的链接
for link in bsObj.find("a",href=re.compile("^(/|.*)"+includeUrl+")")):
if link.attrs['href']is not None:
if link.attrs['href'] not in internalLinks:
internalLinks.appen(link.attrs['href'])
return internalLinks
#获取所有外链接的列表
def getExterbalLinks(bsObj,excludeUrl):
externalLinks =[]
#找出不所有www开头或者http开头且不包含当前的URL的链接
for link in bsObj.findAll("a",href=re.compile("^(http|www)((?!"+excludeUrl+").)*$")):
if link.attrs['href'] is not None:
if link.attrs['href'] not in externalLinks:
externalLinks.append(link.attrs['href'])
return externalLinks
def splitAddress(address):
addressParts = address.replace("http://","").split("/")
return addressParts
def getRandomExternalLinks(startingPage):
html = urlopen(startingPage)
bsObj = BeautifulSoup(html)
externalLinks =getExterbalLinks(bsObj,splitAddress(startingPage)[0])
if len(externalLinks) ==0:
internalLinks = getInternalLinks(startingPage)
return getNextExternalLinks(internalLinks[random.randint(0,len(internalLinks)-1)])
else :
return externalLinks[random.randint(0,len(externalLinks)-1)]
def followExternalOnly(startingSite):
externalLink =getRandomExternalLinks("http://oreilly.com")
print("随机外链接是:"+externalLink)
followExternalOnly(externalLink)
#followExternalOnly("http://oreilly.com")
#收集网站上发现的所有外链接列表
allExtLinks=set()
allIntLinks=set()
def getAllExternalLinks(siteUrl):
html = urlopen(siteUrl)
bsObj = BeautifulSoup(html)
internalLinks =getInternalLinks(bsObj,splitAddress(siteUrl)[0])
externalLinks = getExterbalLinks(bsObj,splitAddress(siteUrl)[0])
for link in externalLinks:
if link not in allExtLinks:
allExtLinks.add(link)
print(link)
for link in internalLinks:
if link not in allIntLinks:
allIntLinks.add(link)
print(link)
getAllExternalLinks("http://oreilly.com")