我有以下数据:
temp<-c("AIR BAGS:FRONTAL" ,"SERVICE BRAKES HYDRAULIC:ANTILOCK",
"PARKING BRAKE:CONVENTIONAL",
"SEATS:FRONT ASSEMBLY:POWER ADJUST",
"POWER TRAIN:AUTOMATIC TRANSMISSION",
"SUSPENSION",
"ENGINE AND ENGINE COOLING:ENGINE",
"SERVICE BRAKES HYDRAULIC:ANTILOCK",
"SUSPENSION:FRONT",
"ENGINE AND ENGINE COOLING:ENGINE",
"VISIBILITY:WINDSHIELD WIPER/WASHER:LINKAGES")
我想创建一个新向量,在存在“:”的情况下仅保留第一个“:”之前的文本,而当“:”不存在时,则保留整个单词。
我曾尝试使用:
temp=data.frame(matrix(unlist(str_split(temp,pattern=":",n=2)),
+ ncol=2, byrow=TRUE))
但在没有“:”的情况下不起作用
我知道这个问题非常类似于: truncate string from a certain character in R,它使用:
sub("^[^.]*", "", x)
但是我对正则表达式不是很熟悉,并且一直在努力反转该示例以仅保留字符串的开头。