正则表达式 – 如何在R中提取字符之间的数字

前端之家收集整理的这篇文章主要介绍了正则表达式 – 如何在R中提取字符之间的数字前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有不同的字符向量包含字符串,如“p.L86 *”,“p.A59fs * 4”,“p.E309 *”等.每个都有不同的数字.我只想提取字符之间的第一个数字,所以预期的解决方案是86,59,309.

我尝试了gsub(“[^ 0-9]”,“”,“p.A59fs * 4”),但它会保存所有数字……

您可以使用sub来获得第一个匹配结果:
x <- c('p.L86*','p.A59fs*4','p.E309*')
sub('\\D*(\\d+).*','\\1',x)
# [1] "86"  "59"  "309"

或者回退到stringi包并匹配它们:

stri_extract_first_regex(x,'\\d+')
原文链接:https://www.f2er.com/regex/356543.html

猜你在找的正则表达式相关文章