Python爬虫四大选择器(正则、BS4、Xpath、CSS)介绍 / 代码实例

本文介绍了Python爬虫中常用的四种选择器:正则表达式、BeautifulSoup(BS4)、XPath和CSS。讨论了它们的使用方法、对比及优缺点。在解析HTML时,lxml库表现高效,而正则表达式功能强大但难于理解。在实际应用中,根据具体需求和效率考虑选择合适的选择器。
摘要由CSDN通过智能技术生成

一、前导库用法

Json库

bs4、lxml主要针对html语言编写的代码,有时请求的内容返回Json代码,就需要用到Json库( Java Script Object Notation)。

Json库常用的方法是json.loads,用于解码 JSON 数据。该函数返回 Python 字段的数据类型。

import json

jsonData = '{"a":1,"b":2,"c":3,"d":4,"e":5}';

text = json.loads(jsonData)
print text

样板:

#获取智联招聘职位信息

import requests
from lxml import etree
import json

def get_urls():
    url = 'https://fe-api.zhaopin.com/c/i/sou?start=0&pageSize=90&cityId=765&salary=0,0&workExperience=-1&education=-1&companyType=-1&employmentType=-1&jobWelfareTag=-1&kw=pcb&kt=3&=0&_v=0.94714929&x-zp-page-request-id=ab2041e0e0b84d7'    
    rec = requests.get(url=url)
    if rec.status_code == 200:
        j = json.loads(rec.text) #解析之后的类型为字典类型
        results = j.get('data').get('results')
        for i in results:
            jobname=i.get('jobName')#获取职位名称
            print(jobname)

get_urls()
lxml库

是python的一个解析库,支持HTML和XML的解析,支持XPath解析方式,而且解析效率非常高。

1、使用 lxml 的 etree 库,可以自动修正 HTML 代码。

from lxml import etree # 导入 lxml etree 库

html = etree.HTML(text) # 获取 html 内容 元素

result = etree.tostring(html)# 将内容元素转换为字符串

print(result.decode("utf-8")
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值