R语言如何提取[]中间的字符串?(R语言字符串提取)

R和Python如何提取[]中间的字符串?(R语言字符串提取)

x <- “[Z序号]>5 && [燃油温度]<5 && [PM开关]==1”
R实现:通过R中的字符串提取函数实现该功能,涉及正则表达式,’[]'的perl正则表达式为:"\\[([^\\[\\]]+)\\]"。
方法一:
library(stringr)
str_extract_all(x, “\\[([^\\[\\]]+)\\]”)
结果:
[[1]]
[1] “[Z序号]” “[燃油温度]” “[PM开关]”

方法二:
unlist(regmatches(x, gregexpr("\\[([^\\[\\]]+)\\]", x, perl=T)))
结果:
[1] “[Z序号]” “[燃油温度]” “[PM开关]”

Python实现:通过Python中的字符串提取函数实现该功能,涉及正则表达式,’[]'的perl正则表达式为:"\[([^\[\]]+)\]",即R中的"\\“变为”\"。
代码:
import re
slotList = re.findall("\[([^\[\]]+)\]", x)
结果:
[‘Z序号’, ‘燃油温度’, ‘PM开关’]

说明:博主原创,转载请注明。

你可能感兴趣的:(R语法)