当前位置: 首页 > news >正文

免费制作的企业网站网站功能开发

免费制作的企业网站,网站功能开发,wordpress布局怎么看,大连公司注册背景 近期工作中要解决两个问题,一个是数据组需要网爬一些图片数据,另外一个是要批量爬取公司用于文档协同的一个网站上的附件。于是乎,就写了两个脚本去完成任务。 爬虫思路 第一步:向确定的url发送请求,接收服务器…

背景

近期工作中要解决两个问题,一个是数据组需要网爬一些图片数据,另外一个是要批量爬取公司用于文档协同的一个网站上的附件。于是乎,就写了两个脚本去完成任务。

爬虫思路

第一步:向确定的url发送请求,接收服务器的响应信息;如果是需要用户登录的网页,需要手动获取cookie信息放入header中,或者模拟登录自动获取cookie。

第二步:对接收到的信息进行解析,找到需要的标签内容(通常是我们需要的图片或文件的url);

第三步:向目标url发送请求,保存数据到本地。

python在网络爬虫方面提供了一些框架,Scrapy、Pyspider等,由于我们要实现的都是小功能,用一些现成的库即可。

爬取附件

1、发送简单请求用urllib.request.urlopen(url)就可以了,但如果要加入headers则可用urllib.request.Request类构造一个request实例,再调用urlopen发送请求。如要用到cookie:

(如果要实现模拟登录自动获取cookie,可参考爬虫实战学习笔记_2 网络请求urllib模块+设置请求头+Cookie+模拟登陆-CSDN博客)

import urllib.requestheaders = {"Cookie": 'confluence.list.pages.cookie=list-content-tree;.......'}req = urllib.request.Request(url, headers=headers)
response = urllib.request.urlopen(req)
2、解析响应体,这里是要找到附件链接的图标,在html中是<a class="filename">的标签元素。用到BeautifulSoup。
from bs4 import BeautifulSouphtml = response.read().decode("utf8")
soup = BeautifulSoup(html, "lxml")
a_list = soup.find_all("a")
for a in a_list:if "class" in a.attrs:if "filename" in a["class"]:filename = a.text.strip()download_url = a['href']print(download_url)           
3、获得文件下载地址后,发送请求,将返回的响应保存到本地即可。这里发请求用的requests库,用urllib.request应该也可以。
import requestsfile = requests.get(download_url, headers=headers)
save_path = './download/'
if not os.path.exists(save_path):os.mkdir(save_path)
save_file = open(os.path.join(save_path, filename), 'wb')
save_file.write(file.content)
save_file.close()
print('save ok')
遗留问题:

上述脚本可针对特定网页进行附件爬取,但多个网页如何先获取到所有网页地址是个棘手的问题。目前只能通过搜寻url规律,发现里面的pageId是9位数字字符,大概确定了范围,进行暴力遍历。

爬取图片

网上关于百度、google爬取关键字图片的开源代码很多,我也是找了一个开源代码进行稍微修改,目前满足实际需要。这里附上代码,供参考。

# -*- coding: UTF-8 -*-"""
import requests
import tqdm
import os
import jsondef configs(search, page, number):url = 'https://image.baidu.com/search/acjson'params = {"tn": "resultjson_com","logid": "11555092689241190059","ipn": "rj","ct": "201326592","is": "","fp": "result","queryWord": search,"cl": "2","lm": "-1","ie": "utf-8","oe": "utf-8","adpicid": "","st": "-1","z": "","ic": "0","hd": "","latest": "","copyright": "","word": search,"s": "","se": "","tab": "","width": "","height": "","face": "0","istype": "2","qc": "","nc": "1","fr": "","expermode": "","force": "","pn": str(60 * page),"rn": number,"gsm": "1e","1617626956685": ""}return url, paramsdef loadpic(number, page, path):while (True):if number == 0:breakurl, params = configs(search, page, number)try:response = requests.get(url, headers=header, params=params).content.decode('utf-8')result = json.loads(response)url_list = []for data in result['data'][:-1]:url_list.append(data['thumbURL'])for i in range(len(url_list)):getImg(url_list[i], 60 * page + i, path)bar.update(1)number -= 1if number == 0:breakpage += 1except Exception as e:print(e)continueprint("\nfinish!")def getImg(url, idx, result_path):img = requests.get(url, headers=header)file = open(result_path + str(idx + 1) + '.jpg', 'wb')file.write(img.content)file.close()if __name__ == '__main__':search = "溜冰" # 爬取的关键词number = 100    #爬取的目标数量result_path = os.path.join(os.getcwd(), search)if not os.path.exists(result_path):os.mkdir(result_path)header = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/66.0.3359.139 Safari/537.36'}bar = tqdm.tqdm(total=number)page = 0loadpic(number, page, result_path)

http://www.yayakq.cn/news/551807/

相关文章:

  • 正规的网站制作联系方式做购物微信网站
  • 做金馆长网站网站企业网站 实名认证
  • 网站建设前端切图厦门 微网站建设公司哪家好
  • 亚马逊网站建设性提议搜盘 资源网
  • 河北保定建设工程信息网站校园网站建设需要数据库吗
  • 网站推广应该注意什么企业建站 wordpress
  • 谷歌做网站推广百度熊掌号 wordpress
  • 淘宝优惠券网站建设教程介绍网站ppt该怎么做
  • 做网站让用seo刷新是哪个键培训教育网站建设
  • 网站排名网络推广wordpress大神
  • 用ps做三网站横幅江苏省建集团领导名单
  • 查网站的关键词排名吗今天哈尔滨最新通告
  • 购物网站html代码怎么做科技小制作视频网站
  • 公司网站内容的更新宁波网络seo推广
  • 做传销一般是不是有网站网站制作手机端
  • 网站开发大全银川网站开发公司
  • lamp网站开发黄金组合 pdfdedecms wap网站模板下载
  • 织梦网站模板教程wordpress move 插件
  • 网站建设分析网站优化培训好学吗
  • 学做预算网站国家企业信息填报系统登录
  • wordpress网站推翻重建百度app智能小程序
  • 全国建设工程招标信息网站临沂市建设局网站公示
  • 企业网站 阿里云wordpress 调用文章内容
  • 商业设计网站有哪些设计师网站上海
  • 上海市工程建设协会网站东莞网站开发方案
  • 招聘网站可以做两份简历吗fusionaccess免费服务器
  • 微平台网站支持html5实现游戏营销策划好的网站
  • 聚美优品返利网站怎么做九一赣州人才网招聘
  • 视频网站怎么做动图网站建设及代运营合同
  • js网站源码下载网站服务器是干什么的