我正在尝试使用下面的代码将append
数据从目录中的31个文件转换为numpy
数组。使用a.append创建所需形状的numpy数组
directory = r"C:\Users\matth\Downloads\AMSRE"
for root, dirs, filenames in os.walk(directory):
for f in filenames:
if f.startswith("AMSR_E_L3_DailyLand_V06_201001"):
log = open(os.path.join(root, f), 'r')
file_name = (("C:\\Users\\matth\\Downloads\\AMSRE\\") + f)
hdf = SD(file_name, SDC.READ)
g = gdal.Open(('HDF4_EOS:EOS_GRID:') + file_name + (':Ascending_Land_Grid:A_Soil_Moisture'))
sm = g.ReadAsArray()
lons = np.fromstring (urllib2.urlopen("ftp://sidads.colorado.edu/pub/tools/easegrid/lowres_latlon/MLLONLSB").read(), \
dtype=np.int32)/100000.
lats = np.fromstring (urllib2.urlopen("ftp://sidads.colorado.edu/pub/tools/easegrid/lowres_latlon/MLLATLSB").read(), \
dtype=np.int32)/100000.
lons = lons.reshape(sm.shape)
lats = lats.reshape(sm.shape)
smm = np.ma.array (sm, mask=np.logical_or (sm==-9999, sm==9999))
soil_moisture = []
soil_moisture.append(smm)
soil_moisture2006 = np.asarray(soil_moisture)
output = np.vstack(soil_moisture2006)
这些文件都开始AMSR_E_L3_DailyLand_V06_201001
,这就是为什么我也行
if f.startswith("AMSR_E_L3_DailyLand_V06_201001"):
一个文件有(586, 1383)
的形状。我想有一个numpy
数组,形状为(31, 586, 1383)
,因为目录中有31个文件。但是,当我在我的代码中创建的output
阵列的shape
的形状是(586, 1383)
,我不知道为什么。有谁知道我可以如何使用append
创建一个形状为(31, 586, 1383)
的numpy数组?提前致谢。
在循环外初始化'soil_moisture'。并在循环之后将它变成一个数组。你不应该需要'vstack'。你是否在小型互动案例中练习过?从小处开始。 – hpaulj