当前位置:   article > 正文

python爬虫实战1-获取当当网近30日好评榜前500本书籍_爬取当当网top前50的书籍并可视化

爬取当当网top前50的书籍并可视化

1、首先打开当当网,点击好评榜,选择近30日,此时浏览器中的URL复制一下,备用

http://bang.dangdang.com/books/fivestars/01.00.00.00.00.00-recent30-0-0-1-1

2、每一页显示20本书,点击下一页可以发现URL变化了,但是只有最后一个数变化,http://bang.dangdang.com/books/fivestars/01.00.00.00.00.00-recent30-0-0-1-2,对应页数

3、F12打开开发者工具,选取页面中的元素,像下面的截图一样,可以找到对应的内容所对应的html代码,这样子到时候就可以通过正则匹配到我们想要的元素了

4、说完思路就可以写代码了,python部分,用到requests模块,获取到页面代码之后,通过正则匹配到对应的内容,最后保存到文本中。

5、首先要获取页面的html代码

  1. def get_html(url):
  2. # 设置请求头,从浏览器复制的,可以没有
  3. headers = {
  4. "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.105 Safari/537.36"
  5. }
  6. try:
  7. response = requests.get(url, headers=headers)
  8. if response.status_code == 200:
  9. return response.text
  10. except Exception as e:
  11. print(e)
  12. return False
'
运行

6、获取到html后就需要用正则匹配获取想要的内容啦,用yield可以节约内存

  1. def parse_result(html):
  2. pattern = re.compile(r'<li>.*?list_num.*?(\d+).</div>.*?<img src="(.*?)".*?title="(.*?)".*?<span class="tuijian">'
  3. r'(.*?)</span>.*?class="publisher_info">.*?target="_blank">(.*?)</a>.*?class="biaosheng">'
  4. r'.*?<span>(.*?)</span>.*?class="price_n">&yen;(.*?)</span>', re.S)
  5. items = re.findall(pattern, html)
  6. for item in items:
  7. yield {
  8. "range": item[0],
  9. "img": item[1],
  10. "title": item[2],
  11. "recommend": item[3],
  12. "author": item[4],
  13. "star": item[5],
  14. "price": item[6]
  15. }
'
运行

7、获取到内容之后呢,就可以写入文本啦

  1. def write_item_to_file(item):
  2. print("write data to book.txt")
  3. with open(PATH, 'a', encoding="UTF-8") as f:
  4. f.write(json.dumps(item, ensure_ascii=False) + '\n')
'
运行

8、整个串起来,这样就把一页的内容提取出来并存到文本中啦

  1. def get_books_info_of_current_page(page):
  2. url = "http://bang.dangdang.com/books/fivestars/01.00.00.00.00.00-recent30-0-0-1-" + str(page)
  3. html = get_html(url)
  4. if html:
  5. items = parse_result(html)
  6. for item in items:
  7. write_item_to_file(item)
  8. else:
  9. print("get {} page failed".format(page))
'
运行

9、最后取25页,就是排名前500的书籍啦

  1. if __name__ == '__main__':
  2. if os.path.exists(PATH):
  3. os.remove(PATH)
  4. for i in range(1, 26):
  5. get_books_info_of_current_page(i)

10、看看出来的效果吧,

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/寸_铁/article/detail/809652
推荐阅读
相关标签
  

闽ICP备14008679号