91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-08-28 19:49:04 來源:腳本之家 閱讀:193 作者:springionic 欄目:開發技術

首先要做的就是去豆瓣網找對應的接口,這里就不贅述了,谷歌瀏覽器抓包即可,然后要做的就是分析返回的json數據的結構:

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

這是接口地址,可以大概的分析一下各個參數的規則:

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

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

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

有了這些,就直接上程序了,因為感覺程序還是比較好懂,主要還是遵從面向對象的程序設計:

import json
import requests


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

  def __init__(self):
    # url_temp中的start的值是動態的,所以這里用{}替換,方便后面使用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): # 發送請求,獲取響應
    print(url)
    response = requests.get(url, headers=self.headers)
    return response.content.decode()

  def get_content_list(self, json_str): # 提取數據
    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): # 實現主要邏輯
    num = 0
    while True:
      # 1. start_url
      url = self.url_temp.format(num)
      # 2. 發送請求,獲取響應
      json_str = self.pass_url(url)
      # 3. 提取數據
      content_list = self.get_content_list(json_str)
      # 4. 保存
      self.save_content_list(content_list)
      if len(content_list) < 20:
        break
      # 5. 構造下一頁url地址,進入循環
      num += 20 # 每一頁有二十條數據


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

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

import json
import requests


class DoubanSpider(object):
  """爬取豆瓣熱門國產電視劇的數據并保存到本地"""
  def __init__(self):
    # url_temp中的start的值是動態的,所以這里用{}替換,方便后面使用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): # 發送請求,獲取響應
    print(url)
    response = requests.get(url, headers=self.headers)
    return response.content.decode()

  def get_content_list(self, json_str): # 提取數據
    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): # 實現主要邏輯
    # 1. start_url
    url = self.url_temp.format(self.num)
    # 2. 發送請求,獲取響應
    json_str = self.pass_url(url)
    # 3. 提取數據
    content_list = self.get_content_list(json_str)
    # 4. 保存
    self.save_content_list(content_list)
    # 5. 構造下一頁url地址,進入循環
    if len(content_list) == 20:
      self.num += 20 # 每一頁有二十條數據
      self.run()


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


最終文件得到的結果:

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

平泉县| 甘洛县| 滨海县| 绥江县| 镇巴县| 建平县| 临泽县| 绵竹市| 缙云县| 五家渠市| 石渠县| 双鸭山市| 财经| 平和县| 丰原市| 新安县| 惠水县| 勃利县| 云霄县| 怀化市| 桐柏县| 资中县| 焦作市| 陆河县| 岳池县| 郴州市| 合肥市| 宿松县| 托克托县| 阜宁县| 务川| 板桥市| 新龙县| 九龙县| 临安市| 苗栗市| 焦作市| 广灵县| 安多县| 广昌县| 岳普湖县|