J'ai un script avec ces deux fonctions:
# Getting content of each page
def GetContent(url):
response = requests.get(url)
return response.content
# Extracting the sites
def CiteParser(content):
soup = BeautifulSoup(content)
print "---> site #: ",len(soup('cite'))
result = []
for cite in soup.find_all('cite'):
result.append(cite.string.split('/')[0])
return result
Quand j'exécute le programme, j'ai l'erreur suivante:
result.append(cite.string.split('/')[0])
AttributeError: 'NoneType' object has no attribute 'split'
Exemple de sortie:
URL: <URL That I use to search 'can be google, bing, etc'>
---> site #: 10
site1.com
.
.
.
site10.com
URL: <URL That I use to search 'can be google, bing, etc'>
File "python.py", line 49, in CiteParser
result.append(cite.string.split('/')[0])
AttributeError: 'NoneType' object has no attribute 'split'
Il peut arriver que la chaîne n’ait rien à l’intérieur, qu’elle soit de type "None", je suppose donc de vérifier d’abord si votre chaîne n’est pas "None"
# Extracting the sites
def CiteParser(content):
soup = BeautifulSoup(content)
#print soup
print "---> site #: ",len(soup('cite'))
result = []
for cite in soup.find_all('cite'):
if cite.string is not None:
result.append(cite.string.split('/'))
print cite
return result
for cite in soup.find_all('cite'):
if( (cite.string is None) or (len(cite.string) == 0)):
continue
result.append(cite.string.split('/')[0])