菜鸟初学Python网页数据抓取01
菜鸟学习python网页数据抓取,以Bing为用户代理,搜索“知网”,抓取到响应后数据界面。
初步学习后的代码如下:
import requests # 1 explict Url url = https://cn.bing.com/search # 2.1 ua pretending headers = Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.0.0 Safari/537.36 Edg/111 .0.1661.41 # 2.2 pakage params into dictionary kw = input(please enter a word:) param = { query : kw } # 2.3 excuting request for the resource in url # 3 and get response data from servers response = requests.get(url = url, params = param, headers =headers) # 4 sustainably store data page_text = response.text fileName = kw + .html with open(fileName,w, encoding = utf-8) as fp: fp.write(page_text) print(fileName,sucessfully storing!!!)
运行后出现报错:
经了解后,发现items是 dic 的属性,而语句中的 ‘headers’是字符串形式,因此出现报错。
headers = Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.0.0 Safari/537.36 Edg/111 .0.1661.41
尝试解决方式如下,将headers封装进 dic :
ua = Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.0.0 Safari/537.36 Edg/111 .0.1661.41 headers = { headers:ua }
问题解决,运行结果和抓取数据如下:
菜鸟学习python网页数据抓取,以Bing为用户代理,搜索“知网”,抓取到响应后数据界面。 初步学习后的代码如下: import requests # 1 explict Url url = https://cn.bing.com/search # 2.1 ua pretending headers = Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.0.0 Safari/537.36 Edg/111 .0.1661.41 # 2.2 pakage params into dictionary kw = input(please enter a word:) param = { query : kw } # 2.3 excuting request for the resource in url # 3 and get response data from servers response = requests.get(url = url, params = param, headers =headers) # 4 sustainably store data page_text = response.text fileName = kw + .html with open(fileName,w, encoding = utf-8) as fp: fp.write(page_text) print(fileName,sucessfully storing!!!) 运行后出现报错: 经了解后,发现items是 dic 的属性,而语句中的 ‘headers’是字符串形式,因此出现报错。 headers = Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.0.0 Safari/537.36 Edg/111 .0.1661.41 尝试解决方式如下,将headers封装进 dic : ua = Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.0.0 Safari/537.36 Edg/111 .0.1661.41 headers = { headers:ua } 问题解决,运行结果和抓取数据如下:上一篇:
通过多线程提高代码的执行效率例子
下一篇:
个人对elasticsearch的理解