// 加载你的 SHP 文件
var china_shp = ee.FeatureCollection("projects/ee-jiag/assets/CHINA_SHP");
// 加载 WorldPop 人口数据 (100m 分辨率)
var worldpop = ee.ImageCollection("WorldPop/GP/100m/pop")
.filterDate('2020-01-01', '2020-12-31') // 筛选 2020 年
.mean() // 获取 2020 年的平均人口分布
.select('population'); // 选择人口字段
// 定义函数:计算每个区域内的人口总数
var calculatePopulation = function(feature) {
// 裁剪人口数据到每个 Feature 的范围
var population = worldpop.clip(feature);
// 计算该区域内人口的总和
var populationSum = population.reduceRegion({
reducer: ee.Reducer.sum(), // 求和
geometry: feature.geometry(), // 使用每个 Feature 的几何范围
scale: 100, // 使用 WorldPop 的分辨率 (100m)
maxPixels: 1e13 // 处理大量像素时的限制
}).get('population'); // 获取人口字段的总和
// 将人口总数作为新属性添加到 Feature,并保留 gb 字段
return feature.set({
'population_sum': populationSum,
'gb': feature.get('gb') // 保留 gb 字段
});
};
// 对 SHP 中的每个 Feature 计算人口总和
var results = china_shp.map(calculatePopulation);
// 打印结果 (以供调试)
print('Results:', results);
// 导出不包含 .geo 列的表格
Export.table.toDrive({
collection: results, // 包含人口求和结果的 FeatureCollection
description: 'PopulationByRegion_GB', // 导出任务名称
fileFormat: 'CSV', // 导出格式
selectors: ['gb', 'population_sum'], // 仅导出 gb 和人口总和字段
});