【无标题】

该代码实现了一个Python爬虫,利用selenium库和XPath解析从CUB网站抓取并下载鸟类的音频文件。它首先搜索指定的鸟类名称,然后遍历所有页面,获取每个音频的链接并使用wget下载。项目已开源在GitHub上。
摘要由CSDN通过智能技术生成

爬取CUB鸟类音频爬虫

环境

Python==3.8.0
elenium
lxml
requests
tqdm
wget

开源在github

https://github.com/Jacky-Android/spider-cub-voice

from selenium import webdriver
from selenium.webdriver.common.by import By
from lxml import etree
import time
import requests
from tqdm import tqdm
import os 
import wget

def pachong(name):
    driver = webdriver.Edge()
    driver.get('https://xeno-canto.org/explore?query='+name )
    try:
        nums = driver.find_element(By.XPATH,'/html/body/div[1]/nav[1]')
        num_ = nums.find_elements(By.XPATH,'ul/li')
        numss = int(num_[-2].text)
        for j in range(1,numss+1):
            num = driver.find_element(By.XPATH,'/html/body/div[1]/table/tbody').find_elements(By.XPATH,'tr')
            for i in num:
                url = (i.find_element(By.XPATH,'td[12]/a[1]').get_attribute('href'))
                
                try:
                    wget.download(url,name+'/')
                except:
                    continue
            
            driver.find_element(By.XPATH,'/html/body/div[1]/nav[1]').find_elements(By.XPATH,'ul/li')[-1].click()
            #time.sleep(10)
            
    except:
        num = driver.find_element(By.XPATH,'/html/body/div[1]/table/tbody').find_elements(By.XPATH,'tr')
        for i in num:
            url = (i.find_element(By.XPATH,'td[12]/a[1]').get_attribute('href'))
            try:
                wget.download(url,name+'/')
            except:
                continue
    driver.close()  

f=open('class.txt')

data = f.readlines()  
f.close()  # 关
for i in tqdm(range(len(data))):
    os.makedirs(data[i].replace('\n','').split(' ')[-1].split('.')[-1]) 
    
    pachong(data[i].replace('\n','').split(' ')[-1].split('.')[-1])
    time.sleep(10+i)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值