网页爬取71

#!/usr/bin/env python
# coding: utf-8
 
# # 一标准库urllib的应用
 
# In[ ]:
 
 
#(1)导入库
import urllib
 
 
# In[3]:
 
 
#(2)创建访问网页的对象
response=urllib.request.urlopen("https://www.jd.com/")
 
 
# In[4]:
 
 
#(3网页对象内容
html=response.read()
 
 
# In[5]:
 
 
#(4)打印网页内容(二进制)
print(html)
 
 
# In[15]:
 
 
#(5) 编码格式改为UTF-8
html=html.decode('UTF-8')
 
 
# In[13]:
 
 
#(6)打印网页内容(UTF-8)
print(html)
 
 
# In[16]:
 
 
#获取网址
print(response.geturl())
 
 
# In[17]:
 
 
#获取网页代码状态200表示正常;404找不到
print(response.getcode())
 
 
# In[18]:
 
 
#获取服务器响应的标头
print(response.getheaders())
 
 
# # 二.第三方库requests的应用
 
# In[19]:
 
 
pip show requests
 
 
# In[20]:
 
 
pip install requests
 
 
# In[21]:
 
 
#导入第三方库
import requests
 
 
# In[22]:
 
 
#提供目标网址
url="http:/jd.com/"
 
 
# In[25]:
 
 
#获取网页的数据信息并保存到变量response中
response=requests.get(url)
 
 
# In[26]:
 
 
#打印网页的原始数据状态
response.text
 
 
# In[27]:
 
 
#打印HTML
print(response.text)
 
 
# In[28]:
 
 
#猜测编码格式
response.encoding
 
 
# In[29]:
 
 
#根据网页分析编码格式
response.apparent_encoding
 
 
# In[32]:
 
 
#分析后的编码方式赋给预测编码方式
response.encoding=response.apparent_encoding
 
 
# In[33]:
 
 
#获取网页代码状态200表示正常;404找不到
response.status_code
 
 
# In[46]:
 
 
import requests
#创建伪装用户代理服务器
kv={'user-agent':'Mozilla/5.0'}
url='https://item.jd.com/10054034809904.html'
try:
    r=requests.get(url,headers=kv)
    #将分析的编码作为备选编码格式
    r.encoding=r.apparent_encoding
    #打印开始0-1000个字符
    print(r.text[:1000])
except:
    print("爬取失败!")
 
 
# # 三.获取一张图片到指定位置
 
# In[61]:
 
 
#导入库
import requests
from PIL import Image
import matplotlib.pyplot as plt
 
#创建伪装用户代理服务器
kv={'user-agent':'Mozilla/5.0'}
#图片地址
url='https://imgcps.jd.com/img-cubic/creative_server_cia_jdcloud/v2/2000366/100042368194/FocusFullshop/CkNqZnMvdDEvMTUzNzMyLzMyLzIyODgwLzMzMDA5LzY0NTk0YjdlRjg2ZTYyYTgxL2FjM2UxNTQ4OTZhYjUxOGMucG5nEgk1LXR5XzBfNTYwAjjui3pCFAoQ5LiJ5pifR2FsYXh5IFMyMxABQhAKDOeVheS6q-S8mOWTgRACQhAKDOeri-WNs-aKoui0rRAGQgoKBuWKm-iNkBAHWMLJ9df0Ag/cr/s/q.jpg'
#图片保存位置
path=r'..\R&Q_pic\pic.jpg'
try:
    #获取网页内容,将伪装代理赋给表头
    r=requests.get(url,headers=kv)
    #打开一个二进制文件(图片)
    f=open(path,'wb')
    #写入一个二进制文件
    f.write(r.content)
    #关闭写入的文件
    f.close()
    
    #文件地址
    im=Image.open(r'..\R&Q_pic\pic.jpg')
    #保存地址 
    im.save(r'..\Stu_pack\pic.jpg')
    
    #显示图片
    plt.imshow(im)
    #隐藏坐标
    plt.axis('off')
except:
    print("爬取失败!")
 
 
# # 四.第三方库beautifulsoup4的应用
 
# In[62]:
 
 
pip show beautifulsoup4
 
 
# In[63]:
 
 
pip install beautifulsoup4
 
 
# In[66]:
 
 
import requests
from bs4 import BeautifulSoup
url='http://jd.com'
r=requests.get(url)
r.text
print(r.text)
 
 
# In[68]:
 
 
#解析器
soup=BeautifulSoup(r.text,'html.parser')
 
 
# In[70]:
 
 
#美化
print(soup.prettify())
 
 
# In[ ]:
 
 
 
 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值