1

我正在尝试复制此 python 脚本来计算特征集合的 NDVI 平均值(在 Earth Engine python 脚本中获取结果)。似乎代码计算了一个结果,但看不到结果。这是代码:

import datetime
import ee
ee.Initialize()

#Feature collection
fc = ee.FeatureCollection("ft:1x290vohty0Wgdn5jL3RlpzryK7dfOPtG6yY213e0");
fc_filtered = fc.filter(ee.Filter.equals('NUM_DECS', 1))
#Image collection
Sentinel_collection = (ee.ImageCollection('COPERNICUS/S2')
    .filterBounds(fc_filtered)
    .filterDate(ee.Date('2017-01-01'),ee.Date('2017-08-01')))

def GetSeries(feature):
  def NDVIcalc(img):
    red = img.select('B4')
    nir = img.select('B8')
    ndvi = nir.subtract(red).divide(nir.add(red)).rename(['NDVI'])
    return (feature
            .set(ndvi.reduceRegion(ee.Reducer.mean(), feature.geometry(), 10))
            .set('date', img.date().format("YYYYMMdd")))

  series = Sentinel_collection.map(NDVIcalc)
  list = series.reduceColumns(ee.Reducer.toList(2), ['date', 'NDVI']).get('list')
  return feature.set(ee.Dictionary(ee.List(list).flatten()))


result = fc_filtered.map(GetSeries)
print(result.getInfo())

给我这个结果:

{'columns': {}, 'type': 'FeatureCollection', 'features': [], 'properties': {'name': 'kmltest', 'DocID': '1x290vohty0Wgdn5jL3RlpzryK7dfOPtG6yY213e0'}}

所以它看起来不像有什么东西从里面出来?

我还没有尝试下一个包含以下内容的地方:

# Get all possible dates.
dates = ee.List(Sentinel_collection.map(function(img) {
      return ee.Feature(null, {'date': img.date().format("YYYYMMdd") })
}).aggregate_array('date'))

# Make a default value for every date.
header = ee.Feature(null, ee.Dictionary(dates, ee.List.repeat(-1, dates.size())))
output = header.merge(result)
ee.batch.Export.table.toDrive(...)

关于做错了什么的任何建议?更愿意将结果放在特征集合中或导出为列表。

4

1 回答 1

0

据我所知,您必须将结果导出到 CSV 驱动器表。所以在这一行之后:

result = fc_filtered.map(GetSeries)

你必须这样写:

task=ee.batch.Export.table.toDrive(collection=result,description='Name_csv_file', fileFormat='CSV')
task.start()

如果您想知道导出是否完成,请使用以下命令进行检查:

task.status()
于 2018-05-30T12:55:57.277 回答