R语言根据经纬度获得对应样本的省份

R语言根据经纬度获得对应样本的省份

一.输入

包含样本的经纬度

二.代码

复制代码
library(sf)
library(dplyr)
library(osmextract)

# 1. 准备省份中英文对照表
province_names <- data.frame(
  name_en = c("Beijing", "Tianjin", "Shanghai", "Chongqing", 
              "Hebei", "Shanxi", "Inner Mongolia", "Liaoning",
              "Jilin", "Heilongjiang", "Jiangsu", "Zhejiang",
              "Anhui", "Fujian", "Jiangxi", "Shandong",
              "Henan", "Hubei", "Hunan", "Guangdong",
              "Guangxi", "Hainan", "Sichuan", "Guizhou",
              "Yunnan", "Tibet", "Shaanxi", "Gansu",
              "Qinghai", "Ningxia", "Xinjiang", "Taiwan"),
  province_cn = c("北京市", "天津市", "上海市", "重庆市",
                  "河北省", "山西省", "内蒙古自治区", "辽宁省",
                  "吉林省", "黑龙江省", "江苏省", "浙江省",
                  "安徽省", "福建省", "江西省", "山东省",
                  "河南省", "湖北省", "湖南省", "广东省",
                  "广西壮族自治区", "海南省", "四川省", "贵州省",
                  "云南省", "西藏自治区", "陕西省", "甘肃省",
                  "青海省", "宁夏回族自治区", "新疆维吾尔自治区", "台湾省")
)

# 2. 读取元数据
metadata <- read.csv("lib_metadata2.csv") %>% 
  filter(!is.na(latitude), !is.na(longitude))

# 3. 获取中国行政区划数据(两种方式任选其一)
# 方式A:使用osmextract获取数据
poly_china <- openstreetmap_fr_zones %>% 
  filter(parent == "china") %>% 
  left_join(province_names, by = c("name" = "name_en")) %>% 
  mutate(province_cn = ifelse(is.na(province_cn), name, province_cn))

# 方式B:使用本地GeoJSON文件(推荐,更稳定)
# china_map <- st_read("D:/path/to/china.json") %>% 
#   left_join(province_names, by = c("name" = "name_en")) %>% 
#   mutate(province_cn = coalesce(province_cn, name))

# 4. 转换为空间点数据
points <- st_as_sf(
  metadata,
  coords = c("longitude", "latitude"),
  crs = 4326,  # WGS84坐标系
  remove = FALSE  # 保留原始列
) %>% 
  st_transform(st_crs(poly_china))  # 转换为与多边形相同的坐标系

# 5. 执行空间连接(带中文省份名称)
result <- st_join(points, poly_china, join = st_within) %>% 
  select(lib_id, genus, species, latitude, longitude, 
         region_en = name, region_cn = province_cn)

# 6. 处理未匹配的点(可选)
if(any(is.na(result$region_cn))) {
  # 方法A:标记未匹配点
  result <- result %>% 
    mutate(region_cn = ifelse(is.na(region_cn), "未知地区", region_cn))
  
  # 方法B:使用最近邻匹配(更精确)
  # unmatched <- result %>% filter(is.na(region_cn))
  # nearest <- st_nearest_feature(unmatched, poly_china)
  # result[is.na(result$region_cn), "region_cn"] <- poly_china$province_cn[nearest]
}

# 7. 检查结果
print(result %>% 
        count(region_cn, sort = TRUE) %>% 
        as.data.frame())

# 8. 保存结果(UTF-8编码支持中文)
write.csv(result, "D:/file/BGI/蚊虫项目/Wolbachia/bam/metadata_with_regions.csv", 
          row.names = FALSE, fileEncoding = "UTF-8")

结果

相关推荐
微风中的麦穗1 小时前
【MATLAB】MATLAB R2025a 详细下载安装图文指南:下一代科学计算与工程仿真平台
开发语言·matlab·开发工具·工程仿真·matlab r2025a·matlab r2025·科学计算与工程仿真
2601_949146532 小时前
C语言语音通知API示例代码:基于标准C的语音接口开发与底层调用实践
c语言·开发语言
开源技术2 小时前
Python Pillow 优化,打开和保存速度最快提高14倍
开发语言·python·pillow
学嵌入式的小杨同学2 小时前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
mftang3 小时前
Python 字符串拼接成字节详解
开发语言·python
jasligea4 小时前
构建个人智能助手
开发语言·python·自然语言处理
kokunka4 小时前
【源码+注释】纯C++小游戏开发之射击小球游戏
开发语言·c++·游戏
云栖梦泽5 小时前
易语言开发从入门到精通:补充篇·网络编程进阶+实用爬虫开发·API集成·代理IP配置·异步请求·防封禁优化
开发语言
java1234_小锋5 小时前
Java高频面试题:SpringBoot为什么要禁止循环依赖?
java·开发语言·面试
铅笔侠_小龙虾5 小时前
Flutter Demo
开发语言·javascript·flutter