python 批量处理nc文件-字符串拼接文件,有规律文件名

简介: python 批量处理nc文件-字符串拼接文件,有规律文件名

有文件如下:


20210416110325317.png


观察文件发现这些文件名有一定的重复,重复的地方我们可以用字符串表示,不一样的地方可以用通配符(*)表示。


##拼接文件名


str1='RSS_SMAP_SSS_L2C_r'
str2='*'#r26259_
str3='_FNL_V04.0.nc'
str4='*'


因为文件中有部分是年月日(20200101)组成,所有这里需要加入一个循环处理。


以后遇到由年月日组成的文件名同样可以处理,同时,由于每一年的每个2月时间会有不同(闰年),所以需要导入一个模块:calendar。具体使用条件可以自己在:bing上搜索:python calendar


import calendar


下面就是对于年月日写循环了


for year in range(2020,2021):#这里只展示2020年
    for month in range(1,13):#表示12个月
        for day in range(1,calendar.monthrange(year,month)[1]+1):#表示每个月的天数


同时,如果不确定是否成功,可以先用golb.glob 模糊查询一下,导入glob模块:


import glob


加入文件的路径,拼接的文件名

path='G:\\'#文件路径,一般需要两个\,别问为什么,不用可能报错
for year in range(2020,2021):
    for month in range(1,2):
        # for day in range(1,calendar.monthrange(year,month)[1]+1):
        for day in range(1,3):
#我的文件放在01号文件夹下面,所以拼接的时候加入了:'%02.0f'%month+'\\'
            fn='%02.0f'%month+'\\'+str1+str2+'_'+'%04.0f'%year+'%02.0f'%month+'%02.0f'%day+\
                'T'+str4+'_'+str4+str3      
            f=glob.glob(path+fn)  #这里需要绝对路径        


查询之后会得到一个list,既你所拥有的所以文件。之后就可以进行其他循环处理啦~~~


举个例子,我这个是nc文件,之后对于每一个nc文件进行循环处理即可:

别忘了导入模块:import netCDF4 as nc


for file in f:
     f1 =nc.Dataset(file,'r') 
      # print(f1)
      lat = `f1.variables['cellat'][:].data`
      lon = f1.variables['cellon'][:].data
      time = f1.variables['time'][:].data


那就顺便讲一下nc文件的读取方式吧!

读取nc文件的办法很多,我这里使用的是nc.Dataset(file,'r')file就是文件名,字符串(str)的格式,如 ‘20200101.nc’


你可以将其付给一个变量,并打印出来print(f1),查找你要输出的数据。

之后f1.variables['你要的数据名称'][:].data

全部的代码如下:


import calendar
import glob
import netCDF4 as nc
str1='RSS_SMAP_SSS_L2C_r'
str2='*'
str3='_FNL_V04.0.nc'
str4='*'
path='G:\\'#文件路径
for year in range(2020,2021):
    for month in range(1,13):
        for day in range(1,calendar.monthrange(year,month)[1]+1):          
            fn='%02.0f'%month+'\\'+str1+str2+'_'+'%04.0f'%year+'%02.0f'%month+'%02.0f'%day+\
                'T'+str4+'_'+str4+str3      
            f=glob.glob(path+fn)     
            for file in f:
                f1 =nc.Dataset(file,'r') 
                # print(f1)
                lat = f1.variables['cellat'][:].data
                lon = f1.variables['cellon'][:].data


                                一个努力学习python的海洋小白
                                水平有限,欢迎指正!!!
                                欢迎评论、收藏。


相关文章
|
19天前
|
Python
1167: 分离字符串(PYTHON)
1167: 分离字符串(PYTHON)
|
23天前
|
Python
【python】python跨文件使用全局变量
【python】python跨文件使用全局变量
|
1天前
|
JSON JavaScript 数据格式
python遍历目录文件_结合vue获取所有的html文件并且展示
python遍历目录文件_结合vue获取所有的html文件并且展示
4 0
|
2天前
|
Python
Python 字符串格式化指南
本文介绍了Python中的三种字符串格式化方法:1) 使用 `%` 操作符,如 `%s` 和 `%d`;2) `str.format()` 方法,通过 `{}` 占位符插入变量;3) Python 3.6 引入的 f-strings,直接在字符串内嵌入变量。此外,还提到了高级用法,如格式控制(如指定小数位数)。这些方法有助于更有效地处理和格式化字符串输出。
3 0
|
7天前
|
存储 Python
用Python实现批量下载文件——代理ip排除万难
用Python实现批量下载文件——代理ip排除万难
|
8天前
|
JSON 关系型数据库 数据库
《Python 简易速速上手小册》第6章:Python 文件和数据持久化(2024 最新版)
《Python 简易速速上手小册》第6章:Python 文件和数据持久化(2024 最新版)
35 0
|
8天前
|
数据挖掘 索引 Python
Python 读写 Excel 文件
Python 读写 Excel 文件
12 0
|
8天前
|
数据安全/隐私保护 Python
Python文件与目录操作:面试中的高频考点
【4月更文挑战第15天】本文介绍了Python文件和目录操作的面试重点,包括文件的读写、目录遍历及权限管理。强调了文件关闭、异常处理、特殊文件判断以及权限位和权限字符串的理解。提供了代码示例,如读写文件、遍历目录和更改文件权限,帮助读者在面试中表现出色。掌握这些技能将对编程求职之路大有裨益。
17 0
|
9天前
|
存储 监控 开发工具
对象存储OSS产品常见问题之python sdk中的append_object方法支持追加上传xls文件如何解决
对象存储OSS是基于互联网的数据存储服务模式,让用户可以安全、可靠地存储大量非结构化数据,如图片、音频、视频、文档等任意类型文件,并通过简单的基于HTTP/HTTPS协议的RESTful API接口进行访问和管理。本帖梳理了用户在实际使用中可能遇到的各种常见问题,涵盖了基础操作、性能优化、安全设置、费用管理、数据备份与恢复、跨区域同步、API接口调用等多个方面。
41 9
|
10天前
|
Python
python学习-函数模块,数据结构,字符串和列表(下)
python学习-函数模块,数据结构,字符串和列表
49 0