urllib简单网页抓取

python网络爬虫学习

  • URL(父类是URI) :统一资源定位符
    构成:协议、主机、地址 (protocol、host、path)
  • urllib包:抓取网页,处理URL,包含模块:

    request:打开读取URL
    error:(可以用try捕捉)
    parse:解析URL
    robotparser:可以测试一个页面是否可以被爬虫下载

  • 用urllib实现简单的网页抓取
# -*- coding: UTF-8 -*-
from urllib import request
import chardet

if __name__ == "__main__":
    response = request.urlopen("http://fanyi.baidu.com")
    html = response.read()
    charset = chardet.detect(html) 
    html = html.decode(charset["encoding"])
    print(html)
    f = open('out.txt', 'w+', encoding='utf-8')
    f.write(html)
    f.close()

读取打印百度翻译的URL,用chardet包实现自动获取编码格式(手动可以从浏览器审查元素1找)
urlopen可以处理string或request对象

	obj = request.Request("http://fanyi.baidu.com/")
    response = request.urlopen(obj)

request对象的其他函数:

geturl():返回URL
info():返回meta标记 2的信息
getcode():返回http状态码 3

注意: 写入txt时要指定utf-8格式(默认gbk)
报错信息:

Traceback (most recent call last):
  File "C:/Users/MACHENIKE/PycharmProjects/untitled/crawler_demo1.py", line 12, in <module>
    f.write(html)
UnicodeEncodeError: 'gbk' codec can't encode character '\u0e02' in position 58895: illegal multibyte sequence

  1. head标签-charset ↩︎

  2. HTML标记head区的关键标签,位于head和title之间,描述一个HTML网页文档的属性,例如作者、日期和时间、网页描述、关键词、页面刷新等。 ↩︎

  3. 百度百科-HTTP状态码 ↩︎

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值