![](/img/trans.png)
[英]R regex - extract strings between two characters for multiple instances
[英]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.