Python3爬虫学习入门教程


Posted in Python onDecember 11, 2018

本文实例讲述了Python3爬虫相关入门知识。分享给大家供大家参考,具体如下:

在网上看到大多数爬虫教程都是Python2的,但Python3才是未来的趋势,许多初学者看了Python2的教程学Python3的话很难适应过来,毕竟Python2.x和Python3.x还是有很多区别的,一个系统的学习方法和路线非常重要,因此我在联系了一段时间之后,想写一下自己的学习过程,分享一下自己的学习经验,顺便也锻炼一下自己。

一、入门篇

这里是Python3的官方技术文档,在这里需要着重说一下,语言的技术文档是用来查的,不是用来学习的,真的没必要把文档背下来,这样学习效率真的很低,不如片学边做,在实践中才会学到东西,不然即使你背会了文档,你仍然很难做出什么项目来,我当初就是在这上面,走了很多弯路,在这里推荐W3cscjool里面的教程非常不错,学习与实践相结合。

1. 少废话,先看东西

第一个例子:爬取知乎首页源码。

#-*-coding:utf-8 -*-
import urllib.request
url = "http://www.zhihu.com"
page_info = urllib.request.urlopen(url).read()
page_info = page_info.decode('utf-8')
print(page_info)

运行结果:

Python3爬虫学习入门教程

运行之后,在IDLE shell里面知乎网站首页的源代码就会被读出来啦Blahblahblah~~~

爬虫定义:

网络爬虫(Web Spider),又被称为网页蜘蛛,是一种按照一定的规则,自动地抓取网站信息的程序或者脚本。

简介:

网络蜘蛛是一个很形象的名字。如果把互联网比喻成一个蜘蛛网,那么Spider就是在网上爬来爬去的蜘蛛。网络蜘蛛是通过网页的链接地址来寻找网页,从 网站某一个页面开始,读取网页的内容,找到在网页中的其它链接地址,然后通过这些链接地址寻找下一个网页,这样一直循环下去,直到把这个网站所有的网页都抓取完为止。

爬虫流程:

①先由urllib的request打开Url得到网页html文档——②浏览器打开网页源代码分析元素节点——③通过Beautiful Soup(后面会讲到)或则正则表达式提取想要的数据——④存储数据到本地磁盘或数据库(抓取,分析,存储)

urllib和urllib2

python2.x里urllib2库,在python3.x里,urllib2改名为urllib,被分成一些子模块:urllib.request, urllib.parseurllib.error。尽管函数名称大多数和原来一样,但是在用新的urllib库时需要注意哪些函数被移动到子模块里了。
urllib是python的标准库,包含了从网络请求数据,处理cookie,甚至改变像请求头和用户代理这些元数据的函数。
urlopen用来打开并读取一个从网络获取的远程对象。它可以轻松读取HTML文件、图像文件或其他任何文件流。

url = "http://www.zhihu.com"
page_info = urllib.request.urlopen(url).read()

urllib.request是urllib的一个子模块,可以打开和处理一些复杂的网址

decode('utf-8')用来将页面转换成utf-8的编码格式,否则会出现乱码

page_info = page_info.decode('utf-8')
print(page_info)

urllib.request.urlopen()方法实现了打开url,并返回一个 http.client.HTTPResponse对象,通过http.client.HTTPResponse的read()方法,获得response body,转码最后通过print()打印出来.

更多关于Python相关内容可查看本站专题:《Python Socket编程技巧总结》、《Python正则表达式用法总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Python实现把json格式转换成文本或sql文件
Jul 10 Python
python 实时遍历日志文件
Apr 12 Python
解析Python中的生成器及其与迭代器的差异
Jun 20 Python
使用Python写CUDA程序的方法
Mar 27 Python
python中学习K-Means和图片压缩
Nov 20 Python
python隐藏终端执行cmd命令的方法
Jun 24 Python
python中如何使用insert函数
Jan 09 Python
Python操作MySQL数据库实例详解【安装、连接、增删改查等】
Jan 17 Python
python如何爬取网页中的文字
Jul 28 Python
Python 的 f-string 可以连接字符串与数字的原因解析
Feb 20 Python
python爬取新闻门户网站的示例
Apr 25 Python
Python采集爬取京东商品信息和评论并存入MySQL
Apr 12 Python
Python3实现爬取简书首页文章标题和文章链接的方法【测试可用】
Dec 11 #Python
python绘制散点图并标记序号的方法
Dec 11 #Python
pandas分别写入excel的不同sheet方法
Dec 11 #Python
使用Python横向合并excel文件的实例
Dec 11 #Python
padas 生成excel 增加sheet表的实例
Dec 11 #Python
python合并已经存在的sheet数据到新sheet的方法
Dec 11 #Python
Python 多线程不加锁分块读取文件的方法
Dec 11 #Python
You might like
提升PHP速度全攻略
2006/10/09 PHP
php 8小时时间差的解决方法小结
2009/12/22 PHP
探讨:如何通过stats命令分析Memcached的内部状态
2013/06/14 PHP
PHP开发中常见的安全问题详解和解决方法(如Sql注入、CSRF、Xss、CC等)
2014/04/21 PHP
ThinkPHP结合ajax、Mysql实现的客户端通信功能代码示例
2014/06/23 PHP
PHP里的单例类写法实例
2015/06/25 PHP
YII2 实现多语言配置的方法分享
2017/01/11 PHP
PHP面向对象程序设计__tostring()和__invoke()用法分析
2019/06/12 PHP
thinkPHP5.1框架使用SemanticUI实现分页功能示例
2019/08/03 PHP
从零开始学习jQuery (八) 插播:jQuery实施方案
2011/02/23 Javascript
JS如何判断移动端访问设备并解析对应CSS
2013/11/27 Javascript
利用a标签自动解析URL分析网址实例
2014/10/20 Javascript
信息页文内画中画广告js实现代码(文中加载广告方式)
2016/01/03 Javascript
基于jQuery实现瀑布流页面
2017/04/11 jQuery
vue router demo详解
2017/10/13 Javascript
React实现阿里云OSS上传文件的示例
2020/08/10 Javascript
vue实现简单全选和反选功能
2020/09/15 Javascript
H5+css3+js搭建带验证码的登录页面
2020/10/11 Javascript
Python的一些用法分享
2012/10/07 Python
Python检测网络延迟的代码
2018/05/15 Python
Python实现Dijkstra算法
2018/10/17 Python
Python面向对象编程基础实例分析
2020/01/17 Python
python模拟点击网页按钮实现方法
2020/02/25 Python
python实现学生成绩测评系统
2020/06/22 Python
HTML5新增加标签和功能概述
2016/09/05 HTML / CSS
eDreams加拿大:廉价航班、酒店和度假
2019/03/29 全球购物
澳洲CFL商城:CHEMIST FOR LESS(中文)
2021/02/28 全球购物
德国净水壶和滤芯品牌:波尔德PearlCo(家用净水器)
2020/04/29 全球购物
历史教育专业个人求职信
2013/12/13 职场文书
函授自我鉴定范文
2014/02/06 职场文书
销售员工作检讨书(推荐篇)
2014/10/18 职场文书
银行自荐信怎么写
2015/03/05 职场文书
医院员工辞职信范文
2015/05/12 职场文书
2016年校园社会综合治理宣传月活动总结
2016/03/16 职场文书
写作技巧:怎样写好一份优秀工作总结?
2019/08/14 职场文书
详解Mysq MVCC多版本的并发控制
2022/04/29 MySQL