标签:联网 网络 ati 路由器 上网 网线 上传 针对 passport
互联网是由于网络设备(网线,路由器,交换机,防火墙等等)和计算机连接而成,像一张网一样。
互联网的核心价值在于数据的共享和传递,数据是放在一台计算机上 的,而将计算机互联到一起的目的就是为了能够方便彼此之间数据的共享和传递,否则你只能拿优盘取别人计算机上拷贝数据。
我们所谓的上网便是由用户端计算机发送请求给目标计算机,将目标计算机上的书籍下载到本地的过程。
爬虫的定义:向网站发起请求,获取资源后分析并提取有用数据的程序
用户获取网络数据的方式是:浏览器提交请求->下载网页代码->解析/渲染成页面。
爬虫学术概念:爬取数据,爬虫就是通过编写程序模拟浏览器上网,让其去互联网上抓取数据的过程。
爬虫程序要做的就是:
模拟浏览器发送请求->下载网页的代码->只提取有用的数据->存放与数据库或者文件中。
爬虫程序只提取网页代码中对我们有用的数据。
模拟浏览器发送请求
requests 模块底层帮助我们封装好了socket套接字,我们只需要关注http协议的通信流程;
? 打开浏览器,输入网址
? 访问目标网站
? 目标网站将数据返回给浏览器
? 浏览器将数据进行渲染
? 然后可以手动获取(ctrl+c ctrl + V)
互联网中最有价值的便是数据,比如天猫商城的商品信息,链家网的租房信息,雪球网的证券投资信息等等,这些数据都代表了各个行业的真金白银,可以说,谁掌握了行业内的第一手数据,谁就成了整个行业的主宰,如果把整个互联网的数据比喻为一座宝藏,那我们的爬虫课程就是来教大家如何来高效地挖掘这些宝藏,掌握了爬虫技能,你就成了所有互联网信息公司幕后的老板,换言之,它们都在免费为你提供有价值的数据。
1、请求方式:
常用的请求方式:GET,POST
其他请求方式:HEAD,PUT,DELETE,OPTHONS
ps:用浏览器演示get与post的区别,(用登录演示post)
post与get请求最终都会拼接成这种形式:k1=xxx&k2=yyy&k3=zzz
post请求的参数放在请求体内:
可用浏览器查看,存放于form data内
get请求的参数直接放在url后
2、请求url
url全称统一资源定位符,如一个网页文档,一张图片
一个视频等都可以用url唯一来确定
url编码
https://www.baidu.com/s?wd=图片
图片会被编码(看示例代码)
网页的加载过程是:
加载一个网页,通常都是先加载document文档,
在解析document文档的时候,遇到链接,则针对超链接发起下载图片的请求
3、请求头
User-agent:请求头中如果没有user-agent客户端配置,
服务端可能将你当做一个非法用户
host
cookies:cookie用来保存登录信息
一般做爬虫都会加上请求头
4、请求体
如果是get方式,请求体没有内容
如果是post方式,请求体是format data
ps:
1、登录窗口,文件上传等,信息都会被附加到请求体内
2、登录,输入错误的用户名密码,然后提交,就可以看到post,正确登录后页面通常会跳转,无法捕捉到post
from urllib.parse import urlencode
import requests
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.88 Safari/537.36',
'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9'
}
# https://www.baidu.com/s?wd=美女
response=requests.get('https://www.baidu.com/s?'+urlencode({'wd':'美女'}),headers=headers)
response=requests.get('https://www.baidu.com/s',params={'wd':'美女'},headers=headers) #params内部就是调用urlencode
reponse.encoding = 'utf8'
print(response.text)
https://www.xicidaili.com/wt/
https://www.kuaidaili.com/free/
http://www.xiladaili.com/
proxies=proxies
import requests
from bs4 import BeautifulSoup
header={'User-Agent':'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36'}
proxies = {'http': '120.236.128.201:8060',
'https': '120.236.128.201:8060'
}
url="http://www.overlove.xin/html/"
header={'User-Agent':'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36'}
req=requests.get(url,headers=header,proxies=proxies,timeout=5)
html=req.text
soup=BeautifulSoup(html,'lxml')
print(soup.text)
标签:联网 网络 ati 路由器 上网 网线 上传 针对 passport
原文地址:https://www.cnblogs.com/SkyOceanchen/p/12165125.html