簡體   English   中英

如何從字符向量中刪除前導數字和點?

[英]How to remove leading digits and dot from character vector?

我有一個只有一列的數據框。 在該列中有兩種類型的數據:

  1. 唯一的字符
  2. “數字.字符”

我想找到第二種類型的數據並刪除數字和點。 我首先將數據從因子轉換為字符。 然后我用'strsplit'來分割第二種類型的數據,但是沒有用。

我的數據的一個例子:

df <- data.frame(Col1 = c("ab","12.cd","cc","dd","34.af"), stringsAsFactors=FALSE)

我想找到"12.cd""34.af"並變成"cd""af"

任何人都可以請解決這個問題嗎?

我們可以匹配一個或多個數字 ( [^0-9]+ ) 后跟一個. 從字符串的開頭 ( ^ ) 並將其替換為空白 ( "" )

df$Col1 <- sub("^[0-9]+\\.", "", df$Col1)
df$Col1
#[1] "ab" "cd" "cc" "dd" "af"

或者另一種選擇是匹配所有非字母字符並替換為空白

sub("[^[:alpha:]]+", "", df$Col1)

數據

df <- data.frame(Col1 = c("ab","12.cd","cc","dd","34.af"), stringsAsFactors=FALSE)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM