Python爬虫学习日志(5)

目录

  • 信息的标记与提取
    • 1.HTML的信息标记
    • 2.信息提取的一般方法
    • 3.基于bs4库的HTML内容查找方法

信息的标记与提取

1.HTML的信息标记

  • HTML(Hyper Text Markup Language)是WWW(World Wide Web)的信息组织方式。
  • 超文本可以将声音、图像和视频嵌入的文本中。
  • HTML通过预定义的<>…标签形式组织不同类型的信息。
  1. XML(eXtensible Makeup Language)

Python爬虫学习日志(5)_第1张图片

  1. JSON(JavaScript Object Notation)

Python爬虫学习日志(5)_第2张图片

  1. YAML(YAML Ain’t Makeup Language)
  • 无类型的键值对,无双引号,#表示注释,-表示并列的值信息,通过缩进表示嵌套关系。
    Python爬虫学习日志(5)_第3张图片

2.信息提取的一般方法

  1. 完整解析信息的标记形式,再提取关键信息
  • XML JSON YAML
    需要标记解析器 例如:bs4库的标签树遍历。
  • 优点:信息解析准确。
  • 缺点:提取过程繁琐,速度慢。
  1. 无视标记形式,直接搜索关键信息
  • 搜索
    对信息的文本查找函数即可。
  • 优点:提取过程简洁,速度较快。
  • 缺点:提取结果准确性与信息内容相关。
  1. 融合方法:结合形式解析与搜索方法,提取关键信息。
    XML JSON YAML 搜索
    需要标记解析器及文本查找函数。

3.基于bs4库的HTML内容查找方法

  1. find_all函数
    Python爬虫学习日志(5)_第4张图片
  • find_all函数非常常用,可以用其简写形式。
    (…) 等价于find_all(…)
    即有:soup(…) 等价于soupfind_all(…)
import requests
from bs4 import BeautifulSoup
import re
r = requests.get("http://python123.io/ws/demo.html")
demo = r.text
soup = BeautifulSoup(demo, "html.parser")
print(soup.find_all('a'))#标签名称name
print("--------------")
print(soup.find_all('a', 'b'))
print("--------------")
print(soup.find_all('p', 'course'))#标签属性值attrs
print("--------------")
print(soup.find_all('a', recursive= False))#子孙检索recursive
print("--------------")
print(soup.find_all(string = "Basic Python"))#字符串string
print("--------------")
print(soup.find_all(string= re.compile("python")))#正则表达式
[<a class="py1" href="http://www.icourse163.org/course/BIT-268001" id="link1">Basic Python</a>, <a class="py2" href="http://www.icourse163.org/course/BIT-1001870001" id="link2">Advanced Python</a>]
--------------
[]
--------------
[<p class="course">Python is a wonderful general-purpose programming language. You can learn Python from novice to professional by tracking the following courses:
<a class="py1" href="http://www.icourse163.org/course/BIT-268001" id="link1">Basic Python</a> and <a class="py2" href="http://www.icourse163.org/course/BIT-1001870001" id="link2">Advanced Python</a>.</p>]
--------------
[]
--------------
['Basic Python']
--------------
['This is a python demo page', 'The demo python introduces several python courses.']
  1. 其他函数
    Python爬虫学习日志(5)_第5张图片

你可能感兴趣的:(Python爬虫基础教程,Python,爬虫,基础)