web-dev-qa-db-fra.com

AttributeError: l'objet 'NoneType' n'a pas d'attribut 'split'

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'
7
MLSC

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
8
user1767754
for cite in soup.find_all('cite'):
    if( (cite.string is None) or (len(cite.string) == 0)):
        continue
    result.append(cite.string.split('/')[0])
1
cppcoder