python爬取netcdf数据

2024-04-20 06:18
文章标签 python 数据 爬取 netcdf

本文主要是介绍python爬取netcdf数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

需要爬取的数据是POES的五个卫星 METOP1,METOP2,NOAA15 ,NOAA18,NOAA19,2014年至2017年的netcdf数据,一个一个下载的话忒别麻烦。

数据地址:https://satdat.ngdc.noaa.gov/sem/poes/data/processed/ngdc/uncorrected/full/

数据排的很好其实,可以按照年份、按照卫星一个一个下载,就不用爬虫跳转url,非常方便,以下载METOP1 2014年的数据为例,打开网页源代码数据下载链接的部分如下:

 

链接在'a'标签中,而且,我们只需要.nc的文件,可以匹配正则表达式http://www.runoob.com/regexp/regexp-syntax.html

python代码如下:

 

"""
Created on Tue Dec 18 10:10:22 2018

@author: Administrator
"""

import urllib
from bs4 import BeautifulSoup
import re

rawurl='https://satdat.ngdc.noaa.gov/sem/poes/data/processed/ngdc/uncorrected/full/2014/metop01/'
content=urllib.request.urlopen(rawurl).read().decode('ascii')#获得html文件
soup=BeautifulSoup(content,'lxml')
link=soup.find_all('a')#找到标签‘a’的所有内容
reinfo=re.compile(r'(poes_m01_2014[0-1][0-9][0-3][0-9])_proc\.nc')#只下载netcdf文件,最简单的正则表达式
file_=r'D:\documents\data\POES\2014\METOP1'#存放下载文件的地址
link_dup=[]
URL1=[]

for i in link:
    a=i.get('href')#获得链接
    if(type(a)==str):#去掉不是String类型的链接
        link_dup.append(a)
    
link_all=list(set(link_dup))#去掉重复的链接
for k in link_all:
    if(re.findall(reinfo,k)):#获得符合正则表达式的链接
        URL1.append(k)
        
for h in URL1:
    a=rawurl+h
    file_name=file_+'\\'+h#保存的文件名
    urllib.request.urlretrieve(a, file_name)#获取文件

 

获取的时候发现了一个问题,假如有一个文件连接比较慢,一时半会下载不下来,就会在这个文件上纠结很久,浪费时间,下不完数据。设置timeout,代码如下。

这篇关于python爬取netcdf数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/919481

相关文章

Mysql如何将数据按照年月分组的统计

《Mysql如何将数据按照年月分组的统计》:本文主要介绍Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql将数据按照年月分组的统计要的效果方案总结Mysql将数据按照年月分组的统计要的效果方案① 使用 DA

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

基于Python实现高效PPT转图片工具

《基于Python实现高效PPT转图片工具》在日常工作中,PPT是我们常用的演示工具,但有时候我们需要将PPT的内容提取为图片格式以便于展示或保存,所以本文将用Python实现PPT转PNG工具,希望... 目录1. 概述2. 功能使用2.1 安装依赖2.2 使用步骤2.3 代码实现2.4 GUI界面3.效

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下:

python连接本地SQL server详细图文教程

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码... 目录一.设置本地账号1.新建用户2.开启双重验证3,开启TCP/IP本地服务二js.python连接实例1.

基于Python和MoviePy实现照片管理和视频合成工具

《基于Python和MoviePy实现照片管理和视频合成工具》在这篇博客中,我们将详细剖析一个基于Python的图形界面应用程序,该程序使用wxPython构建用户界面,并结合MoviePy、Pill... 目录引言项目概述代码结构分析1. 导入和依赖2. 主类:PhotoManager初始化方法:__in

Python从零打造高安全密码管理器

《Python从零打造高安全密码管理器》在数字化时代,每人平均需要管理近百个账号密码,本文将带大家深入剖析一个基于Python的高安全性密码管理器实现方案,感兴趣的小伙伴可以参考一下... 目录一、前言:为什么我们需要专属密码管理器二、系统架构设计2.1 安全加密体系2.2 密码强度策略三、核心功能实现详解

Python Faker库基本用法详解

《PythonFaker库基本用法详解》Faker是一个非常强大的库,适用于生成各种类型的伪随机数据,可以帮助开发者在测试、数据生成、或其他需要随机数据的场景中提高效率,本文给大家介绍PythonF... 目录安装基本用法主要功能示例代码语言和地区生成多条假数据自定义字段小结Faker 是一个 python