首页 > 其他分享 >102102151黄靖数据采集实践三

102102151黄靖数据采集实践三

时间:2023-10-30 23:33:22浏览次数:36  
标签:采集 102102151 self texts item scrapy 黄靖 import data

作业一


(1)要求:使用单线程和多线程的方法爬取中国气象网的限定数量的图片

(2) 下面给出代码实现:
weather.py

import scrapy
from ..items import WeatherItem

class weatherSpider(scrapy.Spider):
    page = 0
    number = 0
    user_agent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/118.0.0.0 Safari/537.36"
    name = "weather"
    allowed_domains = ['weather.com.cn']
    start_urls = ['http://pic.weather.com.cn']

    #爬取图片
    def parse(self, response):
        src_list = response.xpath('/html/body/li/a/img/@src').extract()
        url_list = response.xpath('/html/body/li/a/@href').extract()
        for src in src_list:
            if(self.number < 151):
                print(src)
                item = WeatherItem()
                item['src'] = src
                item['num'] = self.number
                self.number += 1
                yield item

        for list in url_list:
            if(self.page == 51):
                break
            yield scrapy.Request(list, callback = self.parse)



item.py

import scrapy


class WeatherItem(scrapy.Item):   #定义爬取的数据
    src = scrapy.Field()
    url = scrapy.Field()
    num = scrapy.Field()
    pass

pipeline.py


import scrapy
import time
from scrapy.pipelines.images import ImagesPipeline

class imgsPipeLine(ImagesPipeline):
    #根据图片地址进行图片数据的请求
    def get_media_requests(self, item, info):
        yield scrapy.Request(item['img'])

    #指定图片存储的路径
    def file_path(self, request, response=None, info=None, *, item=None):
        imgName = request.url.split('/')[-1]
        return imgName

    def item_completed(self, results, item, info):
        print("successfully saved")
        return item


便可以实现如下效果: ![](/i/l/?n=23&i=blog/3284679/202310/3284679-20231030232321347-684912240.jpg)

(3)心得:这个任务之前在老师布置的作业里已经完成过类似的作业(爬取当当网图片) 这次基本就是重新熟悉一下 值得注意的是 若要改用多线程,则把setting文件中的concurrent_request改为32即可。

作业二


(1)要求:使用scrapy+xpath爬取股票网站信息

(2) 下面给出代码实现:
stock.py

import scrapy
import json
from ..items import EastmoneyItem

class MoneySpider(scrapy.Spider):
    name = "money"
    allowed_domains = ["http://65.push2.eastmoney.com"]
    start_urls = ["http://65.push2.eastmoney.com/api/qt/clist/get?cb=jQuery112406736638761710398_1697718587304&pn=1&pz=20&po=1&np=1&ut=bd1d9ddb04089700cf9c27f6f7426281&fltt=2&invt=2&wbp2u=|0|0|0|web&fid=f3&fs=m:0+t:6,m:0+t:80,m:1+t:2,m:1+t:23,m:0+t:81+s:2048&fields=f1,f2,f3,f4,f5,f6,f7,f8,f9,f10,f12,f13,f14,f15,f16,f17,f18,f20,f21,f23,f24,f25,f22,f11,f62,f128,f136,f115,f152&_=1697718587305"]

    def parse(self, response):
        number=1
        response = response.text
        response=response[42:-2]
        data=json.loads(response)
        data = data['data']['diff']
        for d in data:
            item=EastmoneyItem()
            item['data']=d
            item['number']=number
            number+=1
            yield item

item.py

import scrapy


class EastmoneyItem(scrapy.Item):
    data = scrapy.Field()
    number = scrapy.Field()

pipeline.py


import sqlite3
class EastmoneyPipeline(object):
    con=None
    cursor=None

    def open_spider(self,spider):
        self.con=sqlite3.connect("eastmoney.db")
        self.cursor=self.con.cursor()
        self.cursor.execute("create table money("
                            "id int,"
                            "stocksymbol varchar(16),"
                            "stockname varchar(16),"
                            "LatestPrice varchar(16),"
                            "Pricelimit varchar(16),"
                            "Riseandfall varchar(16),"
                            "volume varchar(16),"
                            "turnover varchar(16),"
                            "amplitude varchar(16),"
                            "max varchar(16),"
                            "min varchar(16),"
                            "today varchar(16),"
                            "yesterday varchar(16))")


    def process_item(self, item, spider):
        try:
            data = item['data']
            num = item['num']
            self.cursor.execute("insert into money values(?,?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)",(num,data['f12'],data['f14'],data['f2'],data['f3'],data['f4'],data['f5'],data['f6'],data['f7'],data['f15'],data['f16'],data['f17'],data['f18']))
            print("Successfully inserted")
            self.con.commit()
        except Exception as e:
            print(e)
            self.con.rollback()
    def close_spider(self,spider):
        self.cursor.close()
        self.con.close()


运行代码后得:

(3)心得:股票交易网站的数据信息的分离较为困难,深刻体会到了Selenium爬取的方便之处,使用scrapy+Selenium的方式加深了对页面爬取的印象。

作业三


要求:熟练掌握 scrapy 中 Item、Pipeline 数据的序列化输出方法;使用scrapy框架+Xpath+MySQL数据库存储技术路线爬取股票相关信息并存储于数据库中。
代码如下:

money.py

import time
import scrapy
from lxml import etree
from ..items import MoneyItem
from selenium import webdriver


class MySpider(scrapy.Spider):
    name = "mySpider3"
    
    def start_requests(self):
        url = 'https://www.boc.cn/sourcedb/whpj/'  # 要爬取的网页URL
        self.driver.get(url)
        time.sleep(1)  # 等待页面加载完毕
        html = etree.HTML(self.driver.page_source)  # 获取网页HTML内容
        yield scrapy.Request(url, self.parse, meta={'html': html})

        # 定义parse方法,用于处理服务器返回的响应

    def parse(self, response):
        # 定义一个全局变量item,这样在处理响应之外的地方也可以引用到这个变量
        global item
        html = response.meta['html']
        lis = html.xpath('/html/body/div/div[5]/div[1]/div[2]/table/tbody/tr')
        number = 1
        # 获取元素
        for link in lis:
            if number != 1:
                texts = link.xpath('./td[1]/text()')
                if texts:
                    name = texts[0]
                else:
                    name = ''
                texts = link.xpath('./td[2]/text()')
                if texts:
                    TBP = texts[0]
                else:
                    TBP = ''
                texts = link.xpath('./td[3]/text()')
                if texts:
                    CBP = texts[0]
                else:
                    CBP = ''
                texts = link.xpath('./td[4]/text()')
                if texts:
                    TSP = texts[0]
                else:
                    TSP = ''
                texts = link.xpath('./td[5]/text()')
                if texts:
                    CSP = texts[0]
                else:
                    CSP = ''
                texts = link.xpath('./td[8]/text()')
                if texts:
                    TIME = texts[0]
                else:
                    TIME = ''

                item = Demo3Item()
                item["currency"] = name
                item["TBP"] = TBP
                item["CBP"] = CBP
                item["TSP"] = TSP
                item["CSP"] = CSP
                item["time"] = TIME
                yield item
            if number == 1:
                number = number + 1

item.py

import scrapy
class MoneyItem(scrapy.Item):
    currency = scrapy.Field()
    TSP = scrapy.Field()
    CSP = scrapy.Field()
    TBP = scrapy.Field()
    CBP = scrapy.Field()
    time = scrapy.Field()
    pass

pipeline.py

import pymysql

class DemoPipeline:
    def process_item(self, item, spider):
        try:
            print(item["currency"])
            print(item["TSP"])
            print(item["CSP"])
            print(item["TBP"])
            print(item["CBP"])
            print(item["time"])
            print()
            # 将数据插入数据库的表中
            mydb = pymysql.connect(host="127.0.0.1", port=3306, user="root", passwd="123456", db="mydb", charset="utf8")
            mycursor = mydb.cursor()
            sql="insert into currency (currency,TSP,CSP,TBP,CBP,time) values (%s,%s,%s,%s,%s,%s)"
            val=(item["currency"], item["TSP"], item["CSP"], item["TBP"], item["CBP"], item["time"])
            mycursor.execute(sql, val)
            mydb.commit()
        except Exception as err:
            print(err)
        return item

运行结果:

(3)心得:与第二题类似,但是总体难度不大

标签:采集,102102151,self,texts,item,scrapy,黄靖,import,data
From: https://www.cnblogs.com/hjing1001/p/17797014.html

相关文章

  • python最新采集京东app商品详情数据(2023-10-30)
    一、技术要点: 1、cookie可以从手机app端用charles抓包获取; 2、无需安装nodejs,纯python源码; 3、商品详情接口为:functionId="wareBusiness"; 4、clientVersion="10.1.4"同时也支持更高的版本; 5、sign签名算法已转成python源码;#-*-coding:UTF-8-*-importreques......
  • python采集京东app搜索商品数据(2023-10-30)
    摘要:   python采集京东app搜索商品数据(2023-10-30)一、技术要点: 1、cookie可以从手机app端用charles抓包获取; 2、无需安装nodejs,纯python源码; 3、搜索接口为:functionId=search; 4、clientVersion="10.1.4"同时也支持更高的版本; 5、sign签名算法已转成pyth......
  • 智能化农业温湿度数据采集网关
    随着科技的发展,各行各业对于环境参数的监测需求不断增加。尤其在某些特定行业,如温室农业、制药、食品、冷库等加工领域,温度和湿度的控制对于保障生产过程的稳定性至关重要。因此,温湿度数据的采集与监控具有越来越重要的意义。温湿度数据采集是通过安装在不同位置的传感器设备来实现......
  • 如何校准振弦采集模块以获得更准确的读数?
    如何校准振弦采集模块以获得更准确的读数?振弦采集模块是一种用于测量振弦传感器输出的模块。在使用振弦采集模块时,校准是非常重要的,因为它可以确保您获得准确的测量结果。本文将介绍如何校准振弦采集模块以获得更准确的读数。1.使用标准信号源进行校准首先,您需要使用标准信号......
  • 如何校准振弦采集模块以获得更准确的读数?
    如何校准振弦采集模块以获得更准确的读数?振弦采集模块是一种用于测量振弦传感器输出的模块。在使用振弦采集模块时,校准是非常重要的,因为它可以确保您获得准确的测量结果。本文将介绍如何校准振弦采集模块以获得更准确的读数。使用标准信号源进行校准首先,您需要使用标准信号源进行校......
  • 2023数据采集与融合技术实践三
    2023数据采集与融合技术实践三作业1:要求:指定一个网站,爬取这个网站中的所有的所有图片,例如:中国气象网(http://www.weather.com.cn)。使用scrapy框架分别实现单线程和多线程的方式爬取。输出信息:将下载的Url信息在控制台输出,并将下载的图片存储在images子文件中,并给出截图。码......
  • 攻克数字--小米机型代号采集
    打开攻克和网页(https://mi.fiime.cn/midaihao)  ......
  • 【医院手麻系统源码】临床设备数据自动采集+无缝集成医院信息系统+自动生成医疗文书
    手术麻醉临床信息系统源码 手术麻醉临床信息系统,采用计算机和通信技术,实现监护仪、麻醉机、输液泵等设备输出数据的自动采集,采集的数据能够如实准确地反映患者生命体征参数的变化,并实现信息高度共享,根据采集结果,综合其他患者数据,自动生成手术麻醉相关医疗文书,以达到提高手术室工作......
  • 影刀RPA-天猫采集-网页监听
    1.google抓包,F12,用价格搜索 2.编写如下影刀代码,既可抓取到详情页数据 ......
  • 影视泛目录站群程序:根据关键词产生10组相关词+电影名/电影简介/电影图片匹配,关键词转
    大家好,今天我要分享的是一款影视泛目录站群程序,它可以根据关键词产生10组相关词,帮助你快速构建一个影视站群。首先,我们需要准备一些关键词,比如说电影名、电影简介、电影图片等。然后,我们进入这款程序,输入关键词,就可以看到相关关键词列表。这些关键词分为两部分,一部分是电影名,一部......