繁体   English   中英

在 R (REGEX) 中的两个字符之间提取 substring

[英]Extract a substring between two characters in R (REGEX)

我无法使用正则表达式从字符串中提取经度和纬度。 字符串是这样的:

[1] "\"42.352800\" data-longitude=\"-71.187500\" \"22\"></div>"

我希望能够分别获得第一个数字“42.352800”和第二个数字“-71.187500”作为两个变量。 因为我将在一堆条目上执行此操作,所以我需要确保它可以获取这些数字,无论它们是正数还是负数。

我想我应该使用正则表达式基本上说:

纬度 <- 从“到”(获取第一个数字)

然后类似的东西得到经度。

这里有什么想法吗? 我对正则表达式比较陌生。

我同意@r2evans 的观点,如果您从网页上抓取这些信息,例如使用rvest获取数据会简单得多。

要回答您的问题,您可以使用str_match获取前两个数字。

string <- "\"42.352800\" data-longitude=\"-71.187500\" \"22\"></div>"

stringr::str_match(string, '(\\d+\\.\\d+).*?(-?\\d+\\.\\d+)')[, -1]
#[1] "42.352800"  "-71.187500"

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM