Python+ArcPy 对栅格数据进行批量重投影

在对遥感图像进行投影时,常常遇到投影信息不一致的问题,因此需要对数据进行投影转换。

采用ArcGIS中Data Management --> Projection and Transformation --> Raster --> Project Raster可以对栅格文件进行逐一投影,但是当文件数量较大时,该操作并不是很方便。因此这里我们采用ArcPy将栅格数据批量转换到与shp文件相同的投影。

import os
import arcpy


arcpy.env.workspace = 'E:/data/'


def GetRaster(file_path, out_path):
    n=0
    files = os.listdir(file_path)
    for file in files:
        type = file.split(".")
        if type[-1] == "tif":
            print file
            raster = os.path.join(file_path,file)
            out_raster = os.path.join(out_path,file)
            projecttype = "Albers_Province.prj"      ## 目标投影信息的文件路径,可以是shapefile对应的prj文件
            arcpy.ProjectRaster_management(raster,out_raster, \
                                           projecttype, "NEAREST","#" , "", "","#")
            n=n+1
    print str(n)+" rasters are processed !!!"



if __name__ ==  "__main__":
    data_path = "./data/"    ## 栅格数据路径
    out_path = "./out/"      ## 输出文件路径
    GetRaster(data_path, out_path)

  • 11
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
### 回答1: arcpy是一个强大的Python库,可以用于处理GIS数据。如果要遍历栅格数据并将数据复制到同名文件夹内,可以使用以下代码: ```python import arcpy import os # 设置工作目录 arcpy.env.workspace = r"path/to/workspace" # 获取所有的栅格数据 raster_list = arcpy.ListRasters() # 遍历所有栅格数据 for raster in raster_list: # 获取栅格数据的路径和名称 raster_path = os.path.dirname(raster) raster_name = os.path.basename(raster) # 创建同名文件夹 output_folder = os.path.join(raster_path, raster_name) if not os.path.exists(output_folder): os.makedirs(output_folder) # 复制栅格数据到同名文件夹内 arcpy.CopyRaster_management(raster, os.path.join(output_folder, raster_name)) ``` 这段代码首先设置工作目录,然后获取所有的栅格数据。接下来,遍历所有的栅格数据,获取栅格数据的路径和名称,并创建同名文件夹。最后,使用`arcpy.CopyRaster_management`将栅格数据复制到同名文件夹内。 ### 回答2: arcpy是一个用于处理地理空间数据的Python模块。要遍历栅格数据并将数据复制到同名文件夹内,可以按照以下步骤进行操作: 1. 首先,需要导入arcpy模块: import arcpy 2. 然后,使用arcpy.ListRasters函数获取当前工作空间中的所有栅格数据: rasters = arcpy.ListRasters() 3. 创建一个循环遍历所有栅格数据: for raster in rasters: # 获取当前栅格数据的名称,并去掉文件扩展名 raster_name = arcpy.Describe(raster).baseName # 创建同名文件夹 folder_path = arcpy.env.workspace + "\\" + raster_name if not arcpy.Exists(folder_path): arcpy.CreateFolder_management(arcpy.env.workspace, raster_name) # 复制栅格数据到同名文件夹内 arcpy.CopyRaster_management(raster, folder_path + "\\" + raster_name) 以上代码中,arcpy.Describe函数用于获取栅格数据的属性信息,arcpy.env.workspace表示当前工作空间路径,arcpy.Exists函数用于判断文件夹是否存在,arcpy.CreateFolder_management函数用于创建文件夹,arcpy.CopyRaster_management函数用于复制栅格数据到指定路径。 这样,就可以通过arcpy遍历栅格数据并将数据复制到同名文件夹内了。 ### 回答3: arcpyArcGIS软件中的一个Python模块,它可以用于地理空间数据的处理和分析。如果想要遍历栅格数据并将数据复制到同名文件夹内,可以使用arcpy模块来完成这个任务。 首先,需要导入arcpy模块,然后使用ListRasters函数来获取栅格数据的列表。这个函数可以接收一个输入文件夹路径,返回一个包含所有栅格数据的列表。 接下来,遍历栅格数据列表。对于每一个栅格数据,首先获取它的文件名(包括扩展名),然后使用os模块中的splitext函数将文件名和扩展名分开。再次使用os模块中的join函数将栅格数据的文件名与输入文件夹路径拼接起来,得到同名文件夹的路径。 然后,使用arcpy中的CopyRaster函数来复制栅格数据。这个函数需要提供栅格数据的输入路径、输出路径和可选的数据格式。 最后,复上述步骤直到遍历完所有栅格数据。 下面是一个示例代码: ```python import arcpy import os input_folder = "输入文件夹路径" # 获取栅格数据列表 raster_list = arcpy.ListRasters("*", "ALL", input_folder) # 遍历栅格数据列表 for raster in raster_list: # 获取栅格数据的文件名和扩展名 file_name, file_extension = os.path.splitext(raster) # 构建同名文件夹的路径 output_folder = os.path.join(input_folder, file_name) # 如果同名文件夹不存在,则创建 if not os.path.isdir(output_folder): os.mkdir(output_folder) # 复制栅格数据到同名文件夹 arcpy.CopyRaster_management(os.path.join(input_folder, raster), os.path.join(output_folder, raster), "", "", "", "NONE", "NONE", "") ``` 以上代码会遍历输入文件夹中的所有栅格数据,并将每一个栅格数据复制到同名的文件夹内。注意要替换"输入文件夹路径"为实际的输入文件夹路径。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小李AI飞刀^_^

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值