实战-赶集网爬虫requests

一、代码

# -*- codeing = utf-8 -*-
# coding=gbk
# @Autor:ggui20
import requests
import re

def parse_page(page_url):
    print(page_url)
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.103 Safari/537.36'
    }
    resp = requests.get(page_url,headers=headers)
    text = resp.text
    houses = re.findall(r"""
        <div.+?ershoufang-list".+?<a.+?js-title.+?>(.+?)</a> # 获取房源的标题
        .+?<dd.+?dd-item.+?<span>(.+?)</span> # 获取房源的户型
        .+?<span.+?<span>(.+?)</span> # 获取房源的面积
        .+?<div.+?price.+?<span.+?>(.+?)</span> # 获取房源的价格
    """,text,re.VERBOSE|re.DOTALL)
    for house in houses:
        print(house)

def main():
    base_url = "http://cs.ganji.com/zufang/pn{}/"
    for x in range(1,11):
        page_url = base_url.format(x)
        parse_page(page_url)
        break

if __name__ == '__main__':
    main()

二、总结:

  1. 如果想要让.代表所有的字符,那么需要在函数后面加re.DOTALL来表示,否则不会代表\n,也就是换行。
  2. 获取数据的时候,都要用非贪婪模式.
  3. 如果正则写得不对,那么获取不到结果,程序会假死,这时候可以把你刚刚写的正则删掉,重新运行下,看下程序还会不会假死
    如果不会假死了,说明正则写得有问题,这是就要去调整了。
  4. 如果正则写的有问题,那么不要去钻牛角尖,去更换一个思路就可以了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值