好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > python實現Scrapy爬取網易新聞

python實現Scrapy爬取網易新聞

熱門標簽:百應ai電銷機器人鄭州 ai地圖標注 女王谷地圖標注 地圖標注推廣單頁 廈門crm外呼系統如何 長春人工智能電銷機器人官網 n400電話申請多少錢 如何在地圖標注文字 西藏快速地圖標注地點

1. 新建項目

在命令行窗口下輸入scrapy startproject scrapytest, 如下


然后就自動創建了相應的文件,如下

2. 修改itmes.py文件

打開scrapy框架自動創建的items.py文件,如下

# Define here the models for your scraped items
#
# See documentation in:
# https://docs.scrapy.org/en/latest/topics/items.html

import scrapy


class ScrapytestItem(scrapy.Item):
 # define the fields for your item here like:
 # name = scrapy.Field()
 pass

編寫里面的代碼,確定我要獲取的信息,比如新聞標題,url,時間,來源,來源的url,新聞的內容等

class ScrapytestItem(scrapy.Item):
 # define the fields for your item here like:
 # name = scrapy.Field()

 title = scrapy.Field()
 timestamp = scrapy.Field()
 category = scrapy.Field()
 content = scrapy.Field()
 url = scrapy.Field()
 
 pass

3. 定義spider,創建一個爬蟲模板

3.1 創建crawl爬蟲模板

在命令行窗口下面 創建一個crawl爬蟲模板(注意在文件的根目錄下面,指令檢查別輸入錯誤,-t 表示使用后面的crawl模板),會在spider文件夾生成一個news163.py文件

scrapy genspider -t crawl codingce news.163.com

然后看一下這個‘crawl'模板和一般的模板有什么區別,多了鏈接提取器還有一些爬蟲規則,這樣就有利于我們做一些深度信息的爬取

import scrapy
from scrapy.linkextractors import LinkExtractor
from scrapy.spiders import CrawlSpider, Rule


class CodingceSpider(CrawlSpider):
 name = 'codingce'
 allowed_domains = ['163.com']
 start_urls = ['http://news.163.com/']

 rules = (
  Rule(LinkExtractor(allow=r'Items/'), callback='parse_item', follow=True),
 )

 def parse_item(self, response):
  item = {}
  #item['domain_id'] = response.xpath('//input[@id="sid"]/@value').get()
  #item['name'] = response.xpath('//div[@id="name"]').get()
  #item['description'] = response.xpath('//div[@id="description"]').get()
  return item

3.2 補充知識:selectors選擇器

支持xpath和css,xpath語法如下

/html/head/title

/html/head/title/text()

//td (深度提取的話就是兩個/)

//div[@class=‘mine']

3.3. 分析網頁內容

在谷歌chrome瀏覽器下,打在網頁新聞的網站,選擇查看源代碼,確認我們可以獲取到itmes.py文件的內容(其實那里面的要獲取的就是查看了網頁源代碼之后確定可以獲取的)

確認標題、時間、url、來源url和內容可以通過檢查和標簽對應上,比如正文部分

主體

標題

時間

分類

4. 修改spider下創建的爬蟲文件

4.1 導入包

打開創建的爬蟲模板,進行代碼的編寫,除了導入系統自動創建的三個庫,我們還需要導入news.items(這里就涉及到了包的概念了,最開始說的–init–.py文件存在說明這個文件夾就是一個包可以直接導入,不需要安裝)

注意:使用的類ExampleSpider一定要繼承自CrawlSpider,因為最開始我們創建的就是一個‘crawl'的爬蟲模板,對應上

import scrapy
from scrapy.linkextractors import LinkExtractor
from scrapy.spiders import CrawlSpider, Rule
from scrapytest.items import ScrapytestItem


class CodingceSpider(CrawlSpider):
 name = 'codingce'
 allowed_domains = ['163.com']

 start_urls = ['http://news.163.com/']

 rules = (
  Rule(LinkExtractor(allow=r'.*\.163\.com/\d{2}/\d{4}/\d{2}/.*\.html'), callback='parse', follow=True),
 )

 def parse(self, response):
  item = {}
  content = 'br>'.join(response.css('.post_content p::text').getall())
  if len(content)  100:
   return

  return item

Rule(LinkExtractor(allow=r'..163.com/\d{2}/\d{4}/\d{2}/..html'), callback=‘parse', follow=True), 其中第一個allow里面是書寫正則表達式的(也是我們核心要輸入的內容),第二個是回調函數,第三個表示是否允許深入

最終代碼

from datetime import datetime
import re

import scrapy
from scrapy.linkextractors import LinkExtractor
from scrapy.spiders import CrawlSpider, Rule
from scrapytest.items import ScrapytestItem


class CodingceSpider(CrawlSpider):
 name = 'codingce'
 allowed_domains = ['163.com']

 start_urls = ['http://news.163.com/']

 rules = (
  Rule(LinkExtractor(allow=r'.*\.163\.com/\d{2}/\d{4}/\d{2}/.*\.html'), callback='parse', follow=True),
 )

 def parse(self, response):
  item = {}
  content = 'br>'.join(response.css('.post_content p::text').getall())
  if len(content)  100:
   return

  title = response.css('h1::text').get()

  category = response.css('.post_crumb a::text').getall()[-1]
  print(category, "=======category")
  time_text = response.css('.post_info::text').get()
  timestamp_text = re.search(r'\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}', time_text).group()
  timestamp = datetime.fromisoformat(timestamp_text)
  print(title, "=========title")
  print(content, "===============content")
  print(timestamp, "==============timestamp")
  print(response.url)
  return item

到此這篇關于python實現Scrapy爬取網易新聞的文章就介紹到這了,更多相關python Scrapy爬取網易新聞內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python爬蟲之教你利用Scrapy爬取圖片
  • python基于scrapy爬取京東筆記本電腦數據并進行簡單處理和分析
  • Scrapy+Selenium自動獲取cookie爬取網易云音樂個人喜愛歌單
  • 如何在scrapy中集成selenium爬取網頁的方法
  • 使用scrapy ImagesPipeline爬取圖片資源的示例代碼
  • scrapy與selenium結合爬取數據(爬取動態網站)的示例代碼
  • Python利用Scrapy框架爬取豆瓣電影示例
  • Python scrapy增量爬取實例及實現過程解析
  • Python爬蟲實戰之使用Scrapy爬取豆瓣圖片

標簽:綿陽 廊坊 亳州 內江 黔東 拉薩 興安盟 渭南

巨人網絡通訊聲明:本文標題《python實現Scrapy爬取網易新聞》,本文關鍵詞  python,實現,Scrapy,爬取,網易,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python實現Scrapy爬取網易新聞》相關的同類信息!
  • 本頁收集關于python實現Scrapy爬取網易新聞的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 中文无码免费| 欧美性受xxxx黑人xxxx| 性巴西18videosex性高清| 精品欧洲videos| 不能说的秘密吉他谱| 亚洲综合憿情五月色丁香色婷婷 | 啊啊啊啊啊啊水好多| 父爱如山动漫无删减版免费观看| 99精品国产AⅤ在线观看苍| 国产女学生一级A片在那里找 | 18亚洲男同志videos网站| 人人看人人插| 在线国产一区二区| 古代荒婬H肉辣文| yealico福利站点规则| 美女把尿囗扒开让蛇钻进去| 漫画美女被艹| 关晓彤被调教出奶水小说| 亚洲丨国产丨精品入口曰日| 免费在线观看污视频网站| chinesebdsm系列国产| 冕宁县| 啦啦啦www在线观看高清视频6 | 任你干精品| 国产日批| 午夜男女刺激爽爽影院蜜芽tv| 青草午夜精品视频在线观看| 日本高清???精品| 女女女hd| 在电影院手伸进她内裤了| 亚洲精品无码一区二区三区久久久 | 在宿舍和男朋友室友做| 国产对白叫床清晰在线播放| 几天没C是不是又痒了网站| 免费高清理伦片手机在线观看| 日韩精品久久日日躁夜夜躁影视| 懂色国产亚洲精产一二三产区精品 | 秋霞电影网院午夜伦不卡A片| 男技师小说| 看车人的七月| 少妇一级婬片A片无码粉色视频|