<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Multiply arrays from two directories to get cloudfree multiband raster in Python Questions</title>
    <link>https://community.esri.com/t5/python-questions/multiply-arrays-from-two-directories-to-get/m-p/580849#M45574</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&lt;SPAN style="color: #242729; background-color: #ffffff;"&gt;I would like to multiply 4band raster from a directory with corresponding 1 band cloud masks to get cloudfree 4band raster in the end. In my attempt, I started with multiplying the first band by the cloud mask. The cloud mask raster are already reclassified ( pixels with values = 0, pixels with no values or clouds= nodata). The problem is that the scripts returns just sometimes one file and&amp;nbsp;returns&amp;nbsp;errors I don't understand:&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;&lt;CODE&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;ERROR &lt;/SPAN&gt;&lt;SPAN class="" style="color: #7d2727; border: 0px; font-weight: inherit; font-size: 13px;"&gt;1&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;:&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt; &lt;/SPAN&gt;&lt;SPAN class="" style="color: #2b91af; border: 0px; font-weight: inherit; font-size: 13px;"&gt;Deleting&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt; D&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;:/&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;SR\2&lt;/SPAN&gt;&lt;SPAN class="" style="color: #7d2727; border: 0px; font-weight: inherit; font-size: 13px;"&gt;0170207&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;_4band&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;.&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;tif failed&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;:&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;&lt;/SPAN&gt;&lt;SPAN class="" style="color: #2b91af; border: 0px; font-weight: inherit; font-size: 13px;"&gt;Permission&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt; denied&lt;/SPAN&gt;
&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;-----------&lt;/P&gt;&lt;P&gt;import pandas as pd&lt;BR /&gt;import gdal&lt;BR /&gt;import os&lt;BR /&gt;import numpy as np&lt;BR /&gt;import glob&lt;/P&gt;&lt;P&gt;SR_images = 'D:/SR'&lt;BR /&gt;sr = glob.glob(os.path.join(SR_images, '*.tif'))&lt;BR /&gt;reclass = 'D:/reclass'&lt;BR /&gt;mask = glob.glob(os.path.join(reclass, '*.tif'))&lt;BR /&gt;savedest = r'D:\maskedsr'&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;for e, i in zip(sr, mask):&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;srraster = gdal.Open(os.path.join(SR_images, e))&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;maskraster = gdal.Open(os.path.join(reclass, i))&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;band1 = srraster.GetRasterBand(1).ReadAsArray()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;band2 = srraster.GetRasterBand(2).ReadAsArray()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;band3 = srraster.GetRasterBand(3).ReadAsArray()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;band4 = srraster.GetRasterBand(4).ReadAsArray()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;bandmask = maskraster.GetRasterBand(1).ReadAsArray()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;geotransform = srraster.GetGeoTransform()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;geoproj = srraster.GetProjection()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;xsize = srraster.RasterXSize&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;ysize = srraster.RasterYSize&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;format1 = "GTiff"&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;driver = gdal.GetDriverByName(format1)&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_datatype = gdal.GDT_UInt16&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;cal_band1 = band1 * bandmask&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;name = e&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;output_path = os.path.join(savedest, name)&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_ds = driver.Create(output_path, xsize, ysize, 1, dst_datatype)&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_ds.GetRasterBand(1).WriteArray(cal_band1)&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_ds.SetGeoTransform(geotransform)&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_ds.SetProjection(geoproj)&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_ds.FlushCache()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_ds = None&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks!&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Sun, 12 Dec 2021 00:58:58 GMT</pubDate>
    <dc:creator>JohannesWissing</dc:creator>
    <dc:date>2021-12-12T00:58:58Z</dc:date>
    <item>
      <title>Multiply arrays from two directories to get cloudfree multiband raster</title>
      <link>https://community.esri.com/t5/python-questions/multiply-arrays-from-two-directories-to-get/m-p/580849#M45574</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&lt;SPAN style="color: #242729; background-color: #ffffff;"&gt;I would like to multiply 4band raster from a directory with corresponding 1 band cloud masks to get cloudfree 4band raster in the end. In my attempt, I started with multiplying the first band by the cloud mask. The cloud mask raster are already reclassified ( pixels with values = 0, pixels with no values or clouds= nodata). The problem is that the scripts returns just sometimes one file and&amp;nbsp;returns&amp;nbsp;errors I don't understand:&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;&lt;CODE&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;ERROR &lt;/SPAN&gt;&lt;SPAN class="" style="color: #7d2727; border: 0px; font-weight: inherit; font-size: 13px;"&gt;1&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;:&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt; &lt;/SPAN&gt;&lt;SPAN class="" style="color: #2b91af; border: 0px; font-weight: inherit; font-size: 13px;"&gt;Deleting&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt; D&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;:/&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;SR\2&lt;/SPAN&gt;&lt;SPAN class="" style="color: #7d2727; border: 0px; font-weight: inherit; font-size: 13px;"&gt;0170207&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;_4band&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;.&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;tif failed&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;:&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt;&lt;/SPAN&gt;&lt;SPAN class="" style="color: #2b91af; border: 0px; font-weight: inherit; font-size: 13px;"&gt;Permission&lt;/SPAN&gt;&lt;SPAN class="" style="color: #303336; border: 0px; font-weight: inherit; font-size: 13px;"&gt; denied&lt;/SPAN&gt;
&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;-----------&lt;/P&gt;&lt;P&gt;import pandas as pd&lt;BR /&gt;import gdal&lt;BR /&gt;import os&lt;BR /&gt;import numpy as np&lt;BR /&gt;import glob&lt;/P&gt;&lt;P&gt;SR_images = 'D:/SR'&lt;BR /&gt;sr = glob.glob(os.path.join(SR_images, '*.tif'))&lt;BR /&gt;reclass = 'D:/reclass'&lt;BR /&gt;mask = glob.glob(os.path.join(reclass, '*.tif'))&lt;BR /&gt;savedest = r'D:\maskedsr'&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;for e, i in zip(sr, mask):&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;srraster = gdal.Open(os.path.join(SR_images, e))&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;maskraster = gdal.Open(os.path.join(reclass, i))&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;band1 = srraster.GetRasterBand(1).ReadAsArray()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;band2 = srraster.GetRasterBand(2).ReadAsArray()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;band3 = srraster.GetRasterBand(3).ReadAsArray()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;band4 = srraster.GetRasterBand(4).ReadAsArray()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;bandmask = maskraster.GetRasterBand(1).ReadAsArray()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;geotransform = srraster.GetGeoTransform()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;geoproj = srraster.GetProjection()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;xsize = srraster.RasterXSize&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;ysize = srraster.RasterYSize&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;format1 = "GTiff"&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;driver = gdal.GetDriverByName(format1)&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_datatype = gdal.GDT_UInt16&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;cal_band1 = band1 * bandmask&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;name = e&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;output_path = os.path.join(savedest, name)&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_ds = driver.Create(output_path, xsize, ysize, 1, dst_datatype)&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_ds.GetRasterBand(1).WriteArray(cal_band1)&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_ds.SetGeoTransform(geotransform)&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_ds.SetProjection(geoproj)&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_ds.FlushCache()&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;dst_ds = None&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks!&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sun, 12 Dec 2021 00:58:58 GMT</pubDate>
      <guid>https://community.esri.com/t5/python-questions/multiply-arrays-from-two-directories-to-get/m-p/580849#M45574</guid>
      <dc:creator>JohannesWissing</dc:creator>
      <dc:date>2021-12-12T00:58:58Z</dc:date>
    </item>
  </channel>
</rss>

