Maison développement back-end Tutoriel Python Explication détaillée des exemples d'exploration récursive du package d'exploration Python BeautifulSoup

Explication détaillée des exemples d'exploration récursive du package d'exploration Python BeautifulSoup

Feb 03, 2017 pm 03:59 PM

Package d'exploration Python BeautifulSoup Explication détaillée des exemples d'exploration récursive

Résumé :

L'objectif principal du robot d'exploration est d'explorer le contenu requis le long du réseau. Leur essence est un processus récursif. Ils doivent d'abord obtenir le contenu de la page Web, puis analyser le contenu de la page et trouver une autre URL, puis obtenir le contenu de la page de cette URL et répéter ce processus.

Prenons Wikipédia comme exemple.

Nous souhaitons extraire tous les liens pointant vers d'autres entrées dans l'entrée Kevin Bacon dans Wikipédia.

# -*- coding: utf-8 -*-
# @Author: HaonanWu
# @Date:  2016-12-25 10:35:00
# @Last Modified by:  HaonanWu
# @Last Modified time: 2016-12-25 10:52:26
from urllib2 import urlopen
from bs4 import BeautifulSoup
 
html = urlopen('http://en.wikipedia.org/wiki/Kevin_Bacon')
bsObj = BeautifulSoup(html, "html.parser")
 
for link in bsObj.findAll("a"):
  if 'href' in link.attrs:
    print link.attrs['href']
Copier après la connexion

Le code ci-dessus peut extraire tous les hyperliens de la page.

/wiki/Wikipedia:Protection_policy#semi
#mw-head
#p-search
/wiki/Kevin_Bacon_(disambiguation)
/wiki/File:Kevin_Bacon_SDCC_2014.jpg
/wiki/San_Diego_Comic-Con
/wiki/Philadelphia
/wiki/Pennsylvania
/wiki/Kyra_Sedgwick
Copier après la connexion

Premièrement, les URL extraites peuvent avoir des doublons

Deuxièmement, certaines URL ne sont pas obligatoires. , comme la barre latérale, l'en-tête, le pied de page, le lien de la barre de répertoire, etc.

Ainsi par observation, nous pouvons constater que tous les liens pointant vers la page d'entrée ont trois caractéristiques :

Ils sont tous dans la balise div avec l'identifiant de bodyContent

Le Le lien URL n'est pas un lien URL contenant des deux-points

sont tous des chemins relatifs commençant par /wiki/ (le chemin absolu complet commençant par http sera également exploré)

from urllib2 import urlopen
from bs4 import BeautifulSoup
import datetime
import random
import re
 
pages = set()
random.seed(datetime.datetime.now())
def getLinks(articleUrl):
  html = urlopen("http://en.wikipedia.org"+articleUrl)
  bsObj = BeautifulSoup(html, "html.parser")
  return bsObj.find("div", {"id":"bodyContent"}).findAll("a", href=re.compile("^(/wiki/)((?!:).)*$"))
 
links = getLinks("/wiki/Kevin_Bacon")
while len(links) > 0:
  newArticle = links[random.randint(0, len(links)-1)].attrs["href"]
  if newArticle not in pages:
    print(newArticle)
    pages.add(newArticle)
    links = getLinks(newArticle)
Copier après la connexion

Le paramètre de getLinks est /wiki/<entry name>, et l'URL de la page est obtenue en la fusionnant avec le chemin absolu de Wikipédia. Capturez toutes les URL pointant vers d'autres termes via des expressions régulières et renvoyez-les à la fonction principale.

La fonction principale appelle des getlinks récursifs et accède de manière aléatoire à une URL non visitée jusqu'à ce qu'il n'y ait plus d'entrées ou qu'elle s'arrête activement.

Ce code peut explorer l'intégralité de Wikipédia

from urllib.request import urlopen
from bs4 import BeautifulSoup
import re
 
pages = set()
def getLinks(pageUrl):
  global pages
  html = urlopen(&quot;http://en.wikipedia.org&quot;+pageUrl)
  bsObj = BeautifulSoup(html, &quot;html.parser&quot;)
  try:
    print(bsObj.h1.get_text())
    print(bsObj.find(id =&quot;mw-content-text&quot;).findAll(&quot;p&quot;)[0])
    print(bsObj.find(id=&quot;ca-edit&quot;).find(&quot;span&quot;).find(&quot;a&quot;).attrs[&#39;href&#39;])
  except AttributeError:
    print(&quot;This page is missing something! No worries though!&quot;)
 
  for link in bsObj.findAll(&quot;a&quot;, href=re.compile(&quot;^(/wiki/)&quot;)):
    if &#39;href&#39; in link.attrs:
      if link.attrs[&#39;href&#39;] not in pages:
        #We have encountered a new page
        newPage = link.attrs[&#39;href&#39;]
        print(&quot;----------------\n&quot;+newPage)
        pages.add(newPage)
        getLinks(newPage)
getLinks(&quot;&quot;)
Copier après la connexion

De manière générale, la limite de récursivité de Python est de 1000 fois. pour définir artificiellement un compteur de récursivité plus grand, ou utiliser d'autres moyens pour permettre au code de continuer à s'exécuter après 1 000 itérations.

Merci d'avoir lu, j'espère que cela pourra vous aider, merci pour votre soutien à ce site !

Pour plus d'exemples d'exploration récursive du package d'exploration Python BeautifulSoup et d'articles connexes, veuillez faire attention au site Web PHP chinois !

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Article chaud

Musée de deux points: Guide de localisation de Bungle Wasteland
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Article chaud

Musée de deux points: Guide de localisation de Bungle Wasteland
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Tags d'article chaud

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser la belle soupe pour analyser HTML? Comment utiliser la belle soupe pour analyser HTML? Mar 10, 2025 pm 06:54 PM

Comment utiliser la belle soupe pour analyser HTML?

Filtrage d'image en python Filtrage d'image en python Mar 03, 2025 am 09:44 AM

Filtrage d'image en python

Comment télécharger des fichiers dans Python Comment télécharger des fichiers dans Python Mar 01, 2025 am 10:03 AM

Comment télécharger des fichiers dans Python

Comment utiliser Python pour trouver la distribution ZIPF d'un fichier texte Comment utiliser Python pour trouver la distribution ZIPF d'un fichier texte Mar 05, 2025 am 09:58 AM

Comment utiliser Python pour trouver la distribution ZIPF d'un fichier texte

Intro au ballon: ajout d'une page de contact Intro au ballon: ajout d'une page de contact Feb 28, 2025 am 10:03 AM

Intro au ballon: ajout d'une page de contact

Comment travailler avec des documents PDF à l'aide de Python Comment travailler avec des documents PDF à l'aide de Python Mar 02, 2025 am 09:54 AM

Comment travailler avec des documents PDF à l'aide de Python

Comment se cacher en utilisant Redis dans les applications Django Comment se cacher en utilisant Redis dans les applications Django Mar 02, 2025 am 10:10 AM

Comment se cacher en utilisant Redis dans les applications Django

Comment effectuer l'apprentissage en profondeur avec TensorFlow ou Pytorch? Comment effectuer l'apprentissage en profondeur avec TensorFlow ou Pytorch? Mar 10, 2025 pm 06:52 PM

Comment effectuer l'apprentissage en profondeur avec TensorFlow ou Pytorch?

See all articles