【ArcGIS Pro】完整的nc文件整理表格模型构建流程及工具练习数据分享

学术科研啥的要用到很多数据,nc文件融合了时间空间数据是科研重要文件。之前分享过怎样将nc文件处理成栅格后整理成表格。小编的读者还是有跑不通整个流程的,再来做一篇总结篇,也分享下练习数据跟工具,如果还是弄不了的,联系小编有偿服务。

1、nc转栅格并投影

这个步骤是重要的一步,将nc文件转栅格,同时创建同名的文件夹(每年一个),将每年12个月的栅格数据存到文件夹里,定义投影。该模型要转多年的,直接用批处理即可。

2、批量裁剪、根据已有文件夹批量建文件夹、文件套文件批量裁剪

这三个模型是实现批量处理搭配使用的。

批量裁剪,我们要的数据是某个行政区域,上一步骤生成的tif,还需要挨个裁剪到相应的行政区域。

因为裁剪之后,文件夹的结构跟全国整体数据结构一致。将全国建立的各年文件夹再新建一个区域的文件夹。

由于总文件下------年份文件夹------月份tif,模型工具只能进行一次迭代。这个模型是结合批量裁剪再进行一次迭代。

3、xxxx降雨转表

区域的降雨tif,得处理成表格。

4、python再整合表格

之前文章:用numpy将nc批量转的降雨表格按市县整理成逐年逐月降雨。是用python的模块numpy整理区域的降雨,按年份整理区域的分月降雨。代码如下(有技术难度可有偿代做):

python 复制代码
'''
将excel表格整理成,2003-2023年辽宁各市降雨量;
'''
import pandas as pd
import numpy as np

# 外面2003到2023的数组
ex_z = []  # 读取的最终列表
for j in range(2003, 2024):
    # 先读取一个文件里的Excel
    wjj = 'G:\\rain\\liaoning\\pre_' + str(j)  # 你的文件夹路径
    ex = []
    for i in range(1, 13):
        # 文件路径
        file_path = wjj + "\\" + str(i) + ".xlsx"
        # 使用pandas读取xls文件
        df = pd.read_excel(file_path)
        ex1 = []
        # 读取每行成列表
        for index, row in enumerate(df.values.tolist()):
            # print(index)
            ex1.append([row[1], round(float(row[5]) / 10, 2)])  # 之前获取的是0.1mm降雨,转化为1mm
        ex.append(ex1)
    ex_z.append(ex)

# print(ex_z[0][0][0])
#
#
# 将列表转数组
a=np.array(ex_z)
# 转换轴
b=np.transpose(a,(0,2,1,3))

# 将四维数组按年份写入Excel
c=b.tolist()
# print(c[0][0])
for i in range(len(c)):
    nian=str(2003+i)
    liem=['prov','city','city_type',nian+'01',nian+'02',nian+'03',nian+'04',nian+'05',nian+'06',nian+'07',nian+'08',nian+'09',nian+'10',nian+'11',nian+'12']
    x=c[i]
    prov='辽宁省'
    city_type='地级市'
    data=[]
    for j in range(len(x)):
        data.append([prov,x[j][0][0],city_type,x[j][0][1],x[j][1][1],x[j][2][1],x[j][3][1],x[j][4][1],x[j][5][1],x[j][6][1],x[j][7][1]
                    ,x[j][8][1],x[j][9][1],x[j][10][1],x[j][11][1]])
    df=pd.DataFrame(data,columns=liem)
    df.to_excel(nian+'.xlsx', index=False)

下面是视频讲解。

nc转表格

练习数据及模型工具

相关推荐
databook9 小时前
Manim实现闪光轨迹特效
后端·python·动效
Juchecar11 小时前
解惑:NumPy 中 ndarray.ndim 到底是什么?
python
用户83562907805111 小时前
Python 删除 Excel 工作表中的空白行列
后端·python
Json_11 小时前
使用python-fastApi框架开发一个学校宿舍管理系统-前后端分离项目
后端·python·fastapi
数据智能老司机18 小时前
精通 Python 设计模式——分布式系统模式
python·设计模式·架构
数据智能老司机19 小时前
精通 Python 设计模式——并发与异步模式
python·设计模式·编程语言
数据智能老司机19 小时前
精通 Python 设计模式——测试模式
python·设计模式·架构
数据智能老司机19 小时前
精通 Python 设计模式——性能模式
python·设计模式·架构
c8i19 小时前
drf初步梳理
python·django
每日AI新事件19 小时前
python的异步函数
python