《R语言实战》学习笔记---Chapter5(4) 高级数据管理 字符处理函数

字符处理函数

tidyverse集合中有一个非常强大的处理字符串的包,可以看这篇文章R语言stringr包处理字符串 - 简书 (jianshu.com)。这篇文章是阅读《R语言实战》的学习笔记,我们继续书中的内容。

注意,涉及到正则表达式的部分都先忽略,先把基础的弄明白,正则表达式需要专门深入学习。

  • 计算字符数量
> x <- c("aghe", "1", "语言", "哈", "ahjdna")
> nchar(x)
[1] 4 1 2 1 6
> length(x)
[1] 5

可以看到,在R里,中文汉字一个字是一个字符宽度。同时注意区分和lengh函数的区别,length返回的是整个数据结构的元素数量

  • 提取或替换一个字符向量中的子串
    函数基本使用格式是substr(x , start ,stop ),可以截取部分子串,也可以替换。
> y <- "122267"
> 
> substr(y, 2, 4)
[1] "222"
> 
> substr(y,2,4 ) <- "ccc"
> 
> print(y)
[1] "1ccc67"

注意,这个替换是在原字符串进行替换,且R索引从1开始。

  • 在字符中搜索某种模式
    使用格式为grep(pattern , x , ignore. case=FALSE, fixed=FALSE)ignore. case设置是否忽略大小写,fixed=FALSE设置是否表示模式是一个正则表达式,暂时先不讨论正则表达式。
> x <- "jakAnh"
> 
> y <- c("slA" , "djkaA")
> 
> grep("A", x, ignore.case = F, fixed = T)
[1] 1
> 
> grep("A", x, ignore.case = T, fixed = T)
[1] 1
Warning message:
In grep("A", x, ignore.case = T, fixed = T) :
  argument 'ignore.case = TRUE' will be ignored
> 
> grep("A", y, ignore.case = F, fixed = T)
[1] 1 2
> 
> grep("A", y, ignore.case = T, fixed = T)
[1] 1 2
Warning message:
In grep("A", y, ignore.case = T, fixed = T) :
  argument 'ignore.case = TRUE' will be ignored

注意,首先这个函数返回的是下标索引,所以在取数据结构子集时可以用。
再看,函数作用的数据结构是向量,即使输入一个字符串,而其中包含多个匹配上的模式,也只会返回1

  • 在字符中搜索模式, 并以文本replacement将其替换

使用格式sub(pattern ,replacement , x , ignore.case=FALSE,fixed=FALSE),后面两个常用设置和上一个函数一样,不多赘述。

> y <- "23777c"
> sub('7', 'M', y, ignore.case = T, fixed = T)
[1] "23M77c"
Warning message:
In sub("7", "M", y, ignore.case = T, fixed = T) :
  argument 'ignore.case = TRUE' will be ignored

注意,它只替换了匹配到的第一个字符。

  • 在split处分割字符向量中的元素
    使用格式strsplit(x , split ,fixed=FALSE),直接看例子,
> y <- "23777c"
> strsplit(y, "7", fixed = T)
[[1]]
[1] "23" ""   ""   "c" 

可以看到,是以7为分隔符,字符被分成了4个部分,其中两个为空。

  • 连接字符串
    有两个基础函数可以使用paste (..., sep = " ", collapse = NULL, recycle0 = FALSE)paste0(..., collapse = NULL, recycle0 = FALSE),直接用帮助文档的例子吧,要说差别,可能就是paste存在一个分隔符选项sep = " "吧。
> nth <- paste0(1:12, c("st", "nd", "rd", rep("th", 9)))
> 
> month.abb  # 内置数据,就和letters一样
 [1] "Jan" "Feb" "Mar" "Apr" "May" "Jun" "Jul" "Aug" "Sep" "Oct" "Nov" "Dec"
> paste(month.abb, "is the", nth, "month of the year.")
 [1] "Jan is the 1st month of the year."  "Feb is the 2nd month of the year." 
 [3] "Mar is the 3rd month of the year."  "Apr is the 4th month of the year." 
 [5] "May is the 5th month of the year."  "Jun is the 6th month of the year." 
 [7] "Jul is the 7th month of the year."  "Aug is the 8th month of the year." 
 [9] "Sep is the 9th month of the year."  "Oct is the 10th month of the year."
[11] "Nov is the 11th month of the year." "Dec is the 12th month of the year."
> library(stringr)
> library(Hmisc)

载入程辑包:‘Hmisc’

The following objects are masked from ‘package:dplyr’:

    src, summarize

The following objects are masked from ‘package:base’:

    format.pval, units

> 
> x <- 'apple'
> y <- 'BANANA'
> 
> toupper(x)
[1] "APPLE"
> tolower(y)
[1] "banana"
> capitalize(x)  # HMisc包函数
[1] "Apple"
> str_to_title(x) # stringr包函数
[1] "Apple"

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容