欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2019年08月10日 11:13:10   作者:springionic  
這篇文章主要介紹了python requests庫(kù)爬取豆瓣電視劇數(shù)據(jù)并保存到本地詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

首先要做的就是去豆瓣網(wǎng)找對(duì)應(yī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

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

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

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

有了這些,就直接上程序了,因?yàn)楦杏X程序還是比較好懂,主要還是遵從面向?qū)ο蟮某绦蛟O(shè)計(jì):

import json
import requests


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

  def __init__(self):
    # url_temp中的start的值是動(dòng)態(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ā)送請(qǐng)求,獲取響應(yīng)
    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') # 寫入換行符進(jìn)行換行
    print('保存成功!')


  def run(self): # 實(shí)現(xiàn)主要邏輯
    num = 0
    while True:
      # 1. start_url
      url = self.url_temp.format(num)
      # 2. 發(fā)送請(qǐng)求,獲取響應(yīng)
      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地址,進(jìn)入循環(huán)
      num += 20 # 每一頁有二十條數(shù)據(jù)


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

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

import json
import requests


class DoubanSpider(object):
  """爬取豆瓣熱門國(guó)產(chǎn)電視劇的數(shù)據(jù)并保存到本地"""
  def __init__(self):
    # url_temp中的start的值是動(dòng)態(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ā)送請(qǐng)求,獲取響應(yīng)
    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') # 寫入換行符進(jìn)行換行
    print('保存成功!')


  def run(self): # 實(shí)現(xiàn)主要邏輯
    # 1. start_url
    url = self.url_temp.format(self.num)
    # 2. 發(fā)送請(qǐng)求,獲取響應(yīng)
    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地址,進(jìn)入循環(huán)
    if len(content_list) == 20:
      self.num += 20 # 每一頁有二十條數(shù)據(jù)
      self.run()


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


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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • python實(shí)現(xiàn)下載指定網(wǎng)址所有圖片的方法

    python實(shí)現(xiàn)下載指定網(wǎng)址所有圖片的方法

    這篇文章主要介紹了python實(shí)現(xiàn)下載指定網(wǎng)址所有圖片的方法,涉及Python針對(duì)頁面的讀取、遍歷及文件操作的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-08-08
  • Keras之自定義損失(loss)函數(shù)用法說明

    Keras之自定義損失(loss)函數(shù)用法說明

    這篇文章主要介紹了Keras之自定義損失(loss)函數(shù)用法說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • python opencv人臉檢測(cè)提取及保存方法

    python opencv人臉檢測(cè)提取及保存方法

    今天小編就為大家分享一篇python opencv人臉檢測(cè)提取及保存方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • Python?設(shè)計(jì)模式行為型解釋器模式

    Python?設(shè)計(jì)模式行為型解釋器模式

    本文介紹了Python解釋器模式,解釋器模式即Interpreter?Pattern,給定一個(gè)語言,定義它的文法的一種表示,并定義一個(gè)解釋器,這個(gè)解釋器使用該表示來解釋語言中的句子,下面文章進(jìn)入更深層學(xué)習(xí),需要的小伙伴可以參考一下
    2022-02-02
  • python3寫爬取B站視頻彈幕功能

    python3寫爬取B站視頻彈幕功能

    本篇文章給大家講解一下如何用python3寫出爬取B站視頻彈幕的功能,有興趣的讀者們參考學(xué)習(xí)下吧。
    2017-12-12
  • python使用socket向客戶端發(fā)送數(shù)據(jù)的方法

    python使用socket向客戶端發(fā)送數(shù)據(jù)的方法

    這篇文章主要介紹了python使用socket向客戶端發(fā)送數(shù)據(jù)的方法,涉及Python使用socket實(shí)現(xiàn)數(shù)據(jù)通信的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-04-04
  • python生成器和yield關(guān)鍵字(完整代碼)

    python生成器和yield關(guān)鍵字(完整代碼)

    這篇文章主要介紹了python生成器和yield關(guān)鍵字,文章主要附上完整的代碼及些許的解釋說明,需要的小伙伴可以參考一下
    2022-01-01
  • Python代碼實(shí)現(xiàn)列表分組計(jì)數(shù)

    Python代碼實(shí)現(xiàn)列表分組計(jì)數(shù)

    這篇文章主要介紹了Python代碼實(shí)現(xiàn)列表分組計(jì)數(shù),利用Python代碼實(shí)現(xiàn)了使用分組函數(shù)對(duì)列表進(jìn)行分組,并計(jì)算每組的元素個(gè)數(shù)的功能,需要的朋友可以參考一下
    2021-11-11
  • Python實(shí)現(xiàn)螺旋矩陣的填充算法示例

    Python實(shí)現(xiàn)螺旋矩陣的填充算法示例

    這篇文章主要介紹了Python實(shí)現(xiàn)螺旋矩陣的填充算法,結(jié)合實(shí)例形式分析了Python實(shí)現(xiàn)螺旋矩陣的相關(guān)循環(huán)、遍歷、判斷、運(yùn)算等操作技巧,需要的朋友可以參考下
    2017-12-12
  • Anaconda安裝之后Spyder打不開解決辦法(親測(cè)有效!)

    Anaconda安裝之后Spyder打不開解決辦法(親測(cè)有效!)

    這篇文章主要給大家介紹了關(guān)于Anaconda安裝之后Spyder打不開解決辦法,文中將解決的過程介紹的非常詳細(xì),親測(cè)有效,對(duì)同樣遇到這個(gè)問題的朋友具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-04-04

最新評(píng)論