针对网站:http://pic.netbian.com/等单个页面有多个照片的页面
废话不多说直接上码
下载的照片均在同一文件夹下的meinv文件夹里
import requests
from lxml import etree
import os
print("请输入您当前网页地址")
# http://pic.netbian.com/
url = input("")
# 头文件
header = {
'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.111 Safari/537.36 Edg/86.0.622.56'
}
response = requests.get(url, header)
# response.encoding = 'utf-8' # 修改乱码方法一
page_text = response.text
tree = etree.HTML(page_text)
# 获取图片表格li
li_list = tree.xpath('//div[@class="slist"]/ul[@class="clearfix"]/li')
# 创建文件夹
if not os.path.exists('./meinvpic'):
os.mkdir('./meinvpic')
for nav in li_list:
# 详细图片网页
img_url = 'http://pic.netbian.com' + nav.xpath('./a/@href')[0]
# print(img_url)
detail_text = requests.get(img_url, header).text
detail_tree = etree.HTML(detail_text)
# 爬取地址,名称
img_src ='http://pic.netbian.com' + detail_tree.xpath('//div[2]/div[1]/div[@class="photo"]/div[1]/div[2]/a/img/@src')[0]
name = detail_tree.xpath('//div[2]/div[1]/div[@class="photo"]/div[1]/div[1]/h1/text()')[0]+'.jpg'
# 修改乱码方法二
name = name.encode('iso-8859-1').decode('gbk')
img_data = requests.get(img_src, header).content
# 图片存储
with open('./meinvpic/' + name, 'wb') as s:
s.write(img_data)
print(name)
print(img_src)