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

我有不同的字符向量包含字符串,如“p.L86 *”,“p.A59fs * 4”,“p.E309 *”等.每个都有不同的数字.我只想提取字符之间的一个数字,所以预期的解决方案是86,59,309.

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

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

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

stri_extract_first_regex(x,'\\d+')

相关文章

正则替换html代码中img标签的src值在开发富文本信息在移动端...
正则表达式
AWK是一种处理文本文件的语言,是一个强大的文件分析工具。它...
正则表达式是特殊的字符序列,利用事先定义好的特定字符以及...
Python界一名小学生,热心分享编程学习。
收集整理每周优质开发者内容,包括、、等方面。每周五定期发...