亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

python requests庫爬取豆瓣電視劇數(shù)據(jù)并保存到本地詳解

系統(tǒng) 2364 0

首先要做的就是去豆瓣網(wǎng)找對應的接口,這里就不贅述了,谷歌瀏覽器抓包即可,然后要做的就是分析返回的json數(shù)據(jù)的結(jié)構(gòu):

https://movie.douban.com/j/search_subjects?type=tv&tag=%E5%9B%BD%E4%BA%A7%E5%89%A7&sort=recommend&page_limit=20&page_start=0

這是接口地址,可以大概的分析一下各個參數(shù)的規(guī)則:

  • type=tv,表示的是電視劇的分類
  • tag=國產(chǎn)劇,表示是國產(chǎn)劇的分類
  • sort參數(shù),這里猜測是一個排序方式
  • page_limit=20,這個一定就是每頁所存取的數(shù)據(jù)數(shù)量了
  • page_start=0,表示的是這頁從哪條數(shù)據(jù)開始,比如第二頁就為page_start=20,第三頁為page_start=40,以此類推
  • 最終我們要用到的主要是page_start和page_limit兩個參數(shù)

下面這里是返回的json數(shù)據(jù)格式,可以看出我們要的是json中subjects列表中的每條數(shù)據(jù),在之后的程序中會把每一個電視劇的信息保存到文件里的一行

python requests庫爬取豆瓣電視劇數(shù)據(jù)并保存到本地詳解_第1張圖片

有了這些,就直接上程序了,因為感覺程序還是比較好懂,主要還是遵從面向?qū)ο蟮某绦蛟O計:

            
import json
import requests


class DoubanSpider(object):
  """爬取豆瓣熱門國產(chǎn)電視劇的數(shù)據(jù)并保存到本地"""

  def __init__(self):
    # url_temp中的start的值是動態(tài)的,所以這里用{}替換,方便后面使用format方法
    self.url_temp = 'https://movie.douban.com/j/search_subjects?type=tv&tag=%E5%9B%BD%E4%BA%A7%E5%89%A7&sort=recommend&page_limit=20&page_start={}'
    self.headers = {
      'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36',
    }

  def pass_url(self, url): # 發(fā)送請求,獲取響應
    print(url)
    response = requests.get(url, headers=self.headers)
    return response.content.decode()

  def get_content_list(self, json_str): # 提取數(shù)據(jù)
    dict_ret = json.loads(json_str)
    content_list = dict_ret['subjects']
    return content_list

  def save_content_list(self, content_list): # 保存
    with open('douban.txt', 'a', encoding='utf-8') as f:
      for content in content_list:
        f.write(json.dumps(content, ensure_ascii=False)) # 一部電視劇的信息一行
        f.write('\n') # 寫入換行符進行換行
    print('保存成功!')


  def run(self): # 實現(xiàn)主要邏輯
    num = 0
    while True:
      # 1. start_url
      url = self.url_temp.format(num)
      # 2. 發(fā)送請求,獲取響應
      json_str = self.pass_url(url)
      # 3. 提取數(shù)據(jù)
      content_list = self.get_content_list(json_str)
      # 4. 保存
      self.save_content_list(content_list)
      if len(content_list) < 20:
        break
      # 5. 構(gòu)造下一頁url地址,進入循環(huán)
      num += 20 # 每一頁有二十條數(shù)據(jù)


if __name__ == '__main__':
  douban_spider = DoubanSpider()
  douban_spider.run()
          

上面是利用循環(huán)遍歷每一頁,后來我又想到用遞歸也可以,雖然遞歸效率可能不高,這里還是展示一下,只需要改幾個地方而已:

            
import json
import requests


class DoubanSpider(object):
  """爬取豆瓣熱門國產(chǎn)電視劇的數(shù)據(jù)并保存到本地"""
  def __init__(self):
    # url_temp中的start的值是動態(tài)的,所以這里用{}替換,方便后面使用format方法
    self.url_temp = 'https://movie.douban.com/j/search_subjects?type=tv&tag=%E5%9B%BD%E4%BA%A7%E5%89%A7&sort=recommend&page_limit=20&page_start={}'
    self.headers = {
      'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36',
    }
    self.num = 0

  def pass_url(self, url): # 發(fā)送請求,獲取響應
    print(url)
    response = requests.get(url, headers=self.headers)
    return response.content.decode()

  def get_content_list(self, json_str): # 提取數(shù)據(jù)
    dict_ret = json.loads(json_str)
    content_list = dict_ret['subjects']
    return content_list

  def save_content_list(self, content_list): # 保存
    with open('douban2.txt', 'a', encoding='utf-8') as f:
      for content in content_list:
        f.write(json.dumps(content, ensure_ascii=False)) # 一部電視劇的信息一行
        f.write('\n') # 寫入換行符進行換行
    print('保存成功!')


  def run(self): # 實現(xiàn)主要邏輯
    # 1. start_url
    url = self.url_temp.format(self.num)
    # 2. 發(fā)送請求,獲取響應
    json_str = self.pass_url(url)
    # 3. 提取數(shù)據(jù)
    content_list = self.get_content_list(json_str)
    # 4. 保存
    self.save_content_list(content_list)
    # 5. 構(gòu)造下一頁url地址,進入循環(huán)
    if len(content_list) == 20:
      self.num += 20 # 每一頁有二十條數(shù)據(jù)
      self.run()


if __name__ == '__main__':
  douban_spider = DoubanSpider()
  douban_spider.run()
          


最終文件得到的結(jié)果:

python requests庫爬取豆瓣電視劇數(shù)據(jù)并保存到本地詳解_第2張圖片

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。


更多文章、技術(shù)交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产精品99久久久久久www | 中文亚洲日韩欧美 | 日本黄色录像 | 日韩不卡视频在线观看 | 夜夜躁日日躁狠狠 | 美国美女一级毛片免费全 | 国产欧美一区二区三区视频 | 91精品国产色综合久久 | 最新国产午夜精品视频不卡 | 日韩成人三级 | 色老头一区二区三区 | 国产东北露脸对白 | 亚洲欧美日韩久久一区 | 亚洲精品在线免费 | 毛茸茸性毛茸茸大b | 毛片免费观看的视频 | 精品欧美一区二区三区四区 | 4虎成人 | 成人a视频在线观看 | 欧美一级毛片一级 | 中文字幕在线观看2023 | 日一级片 | 一男一女一级毛片 | 久久综合国产 | 中文字幕不卡在线高清 | 国产欧美国产精品第二区 | 欧美日韩色 | 天天看天天干 | 国产精品综合一区二区三区 | 欧美日韩视频在线成人 | 奇米网7777| 97se狠狠狠狠狼亚洲综合网 | 啪啪99久久综合精品色 | 久草视频免费在线观看 | 精品国产线拍大陆久久尤物 | 久久久久中文 | 成年午夜视频免费观看视频 | 性欧美4k高清精品 | 毛片在线视频观看 | 精品欧美一区手机在线观看 | 日韩欧美一区二区在线 |