并行处理时未将栅格写入列表
创始人
2024-12-18 14:30:25
0

可以使用multiprocessing库来实现多进程并行处理,以确保所有生成的栅格都被正确地写入到列表中。以下是示例代码:

import multiprocessing
from arcpy.sa import *

# 输入数据和输出路径
input_rasters = [...] # 输入栅格列表
output_folder = "C:/output"

# 创建一个共享变量来保存所有生成的栅格
manager = multiprocessing.Manager()
output_rasters = manager.list()

# 定义一个处理栅格的函数
def process_raster(in_raster, out_raster):
    out_raster = Raster(in_raster) * 2 # 假设这里进行了一些处理
    out_raster.save(out_raster)

    # 将处理后的栅格添加到共享的栅格列表中
    output_rasters.append(out_raster)

if __name__ == '__main__':
    # 使用多进程并行处理栅格
    pool = multiprocessing.Pool()
    results = []
    for in_raster in input_rasters:
        out_raster = os.path.join(output_folder, os.path.basename(in_raster) + ".tif")
        # 使用进程池来异步处理栅格
        result = pool.apply_async(process_raster, [in_raster, out_raster])
        results.append(result)
    pool.close()
    pool.join()

    # 使用共享变量来输出结果
    print(list(output_rasters))

在这个示例中,我们使用了multiprocessing.Manager()来创建了一个共享变量output_rasters,可以在不同的进程中共享。我们还定义了一个process_raster()函数来处理每个输入栅格。这个函数将处理后的栅格保存到磁盘,并使用output_rasters.append(out_raster)将处理后的栅格添加到共享列表中。在主程序中,我们使用了multiprocessing.Pool()来异步处理输入栅格,并将返回的结果存储在一个results列表中。最后,我们遍历output_rasters

相关内容

热门资讯

八分钟了解!一起宁德游戏钓蟹输... 八分钟了解!一起宁德游戏钓蟹输赢规律,白金岛跑得快辅助工具,黑科技教程(有挂脚本)小薇(透视辅助)致...
8分钟了解!衡阳丫丫字牌外 挂... 8分钟了解!衡阳丫丫字牌外 挂,拱趴大菠萝切牌规律,wpk教程(有挂普及)1、完成拱趴大菠萝切牌规律...
八分钟了解!广西跑得快助赢神器... 八分钟了解!广西跑得快助赢神器购买,赣牌圈开挂是真的吗,AA德州教程(有挂方法);1、超多福利:超高...
一分钟了解!大凉山生活号跑得快... 一分钟了解!大凉山生活号跑得快有挂吗,哈局十三张安卓辅助,玩家教你(有挂教学)在进入大凉山生活号跑得...
六分钟了解!闽悦麻将是不是有挂... 六分钟了解!闽悦麻将是不是有挂,花花生活圈怎么老是输,教你攻略(有挂工具)花花生活圈怎么老是输辅助器...
一分钟了解!小程序的雀神麻将怎... 一分钟了解!小程序的雀神麻将怎么玩才会赢,中至窝龙如何提高自己的胜率,专业教程(有挂神器)1、在小程...
3分钟了解!皮皮斗地主外 挂,... 3分钟了解!皮皮斗地主外 挂,兴动棋牌麻将有挂吗,解密教程(有挂插件)兴动棋牌麻将有挂吗辅助器中分为...
七分钟了解!胡乐辅助器免费版,... 七分钟了解!胡乐辅助器免费版,掌心圈麻将有挂是真的吗,详细教程(有挂解说)一、掌心圈麻将有挂是真的吗...
8分钟了解!随意玩拼三张能破解... 8分钟了解!随意玩拼三张能破解吗,中至麻将发牌规律,攻略方法(有挂科普)1、玩家可以在随意玩拼三张能...
二分钟了解!蜂娱棋牌2有挂吗,... 二分钟了解!蜂娱棋牌2有挂吗,拱趴十三水输赢规律,德州教程(有挂辅助)1.拱趴十三水输赢规律 ai辅...