R学习笔记 第五篇:字符串操作
文本数据存储在字符向量中,字符向量的每个元素都是字符串,而非单独的字符。在R中,可以使用双引号,或单引号表示字符。
一,字符串中的字符数量
函数nchar()用于获得字符串中的字符数量:
> s <- 'read'
> nchar(s)
[]
二,转义字符
R语言使用“\”,把特定的字符转义为特殊字符,例如 “\t”是制表符,换行符是“\n”,或者 “\r\n”,通常情况下,\r是回车符,把光标移动到当前行的开始,并覆盖当前行已经存在的数据,而\n是换行,把光标移动到一下行;
常用的转义字符是:使用两个“\\”,打印“\”;在字符串中包含双引号或单引号,使用“\"”,或“\'”;如果在双引号中使用单引号,或者在单引号中使用双引号,那么不需要对引号进行转义,R会打印引号。
三,更改字符的大小写
toupper()和tolower()函数,用于把字符串中的字符全部转换为大写或小写:
> toupper('Vic')
[1] "VIC"
> tolower('Vic')
[1] "vic"
四,拼接字符
函数paste()用于把不同的字符向量组合起来,传递的参数是字符向量,返回的数据类型是字符向量:
paste (..., sep = " ", collapse = NULL)
paste()函数按照向量元素的位置顺序,把向量中的元素拼接在一起,中间以sep参数(默认值是空格)分割,collapse参数用于把结果向量(字符向量)的各个元素折叠成一个单独的字符串,使用collapse指定的字符把结果向量的各个元素拼接在一起:
> paste(c('red','yellow'),'lorry')
[] "red lorry" "yellow lorry"
> paste(c('red','yellow'),c('lorry','car'))
[] "red lorry" "yellow car"
> paste(c('red','yellow'),c('lorry','car'),collapse=',')
[] "red lorry,yellow car"
五,截取字符串
substr或substring函数用于从字符串中截取子串,字符串的位置从1开始,
substr(x, start, stop)
substring(text, first, last = 1000000L)
1,当start和stop是正整数时,substr和substring函数的行为是相同的:
> substr('R is free software',1,6)
[] "R is f"
> substring('R is free software',1,6)
[] "R is f"
2,当start和stop是向量时,substr和substring函数的行为是不相同的:
> substring('R is free software',1:4,6:9)
[] "R is f" " is fr" "is fre" "s free"
> substr('R is free software',1:4,6:9)
[] "R is f"
六,分割字符串
函数strsplit用于按照指定的字符把长的字符串分割成断的子字符串,
strsplit(x, split, fixed = FALSE)
参数split是用于分割字符串,当参数fixed为TRUE时,表示字符串完全匹配split分隔符;当fixed参数为FALSE时,表示参数split是包含正则表达式的字符,使用正则匹配。函数返回的结果是字符列表,一个列表项对应一个字符串。
> strsplit('ab,cd,ef',',')
[[]]
[] "ab" "cd" "ef"
七,格式化数字
format函数用于把数字(numeric)类型转换成字符类型,formatC函数使用C语言风格来指定输出的格式,而更通用的C风格的格式化函数是sprintf,第一个参数包含字符串或数字变量的占位符,其他参数逐个对应这些占位符,sprintf函数的占位符:
- %s:字符串
- %f:浮点型
- %d:整数
- %e :科学计数法
格式化函数的定义:
format(x, digits = NULL, nsmall = 0L)
formatC(x, digits = NULL, format = NULL, flag = "")
sprintf(fmt, ...)
参数注释:
- digits:是一个建议值,用于设置数字的总位数,包括小数点左边和右边;
- nsmall:小数位的数量;
- format:数字的格式,跟占位符相似: "d" (for integers), "f", "e", "E", "g", "G", "fg" (for reals), or "s" (for strings).
- flag:在数字前添加符号
例如,format函数和sprintf函数对数字格式化输出的结果是:
> format(1.3)
[1] "1.3"
> sprintf('%f, %d',1.3,1)
[1] "1.300000, 1"
八,stringr包
stringr包对字符串操作提供了一致的包装,使用R操作字符串,基本上使用该包提供的函数就够了,在使用之前,首先引用stringr包:
library(stringr)
1,字符串长度
str_length 函数计算字符串的长度
> str_length("vic")
[] 3
2,截取子串
str_sub函数用于截取子字符串,start和end用于指定子串的开始位置和结束位置,在end中,如果使用负数,表示从字符串的末尾向前计数。
str_sub(string, start = 1L, end = -1L)
例如,从字符串向量中截取子串:
> x <- c("abcdef", "ghifjk")
> str_sub(x, , )
[] "c" "i"
> str_sub(x, , -)
[] "cde" "ifj"
3,字符的序号
获取字符向量中字符的序号
x <- c("y", "i", "k")
str_order(x)
#> []
4,对字符进行排序
x <- c("y", "i", "k")
str_sort(x)
#> [] "i" "k" "y"
5,扩展字符串
str_pad(string, width, side = c("left", "right", "both"), pad = " ")
6,去掉字符串两端的空格
str_trim(string, side = c("both", "left", "right"))
7,转换大小写
str_to_upper(string, locale = "en")
str_to_lower(string, locale = "en")
str_to_title(string, locale = "en")
8,按照模式匹配
str_detect函数按照指定的模式查找字符串,返回逻辑值;str_subset返回匹配模式的字符串:
str_detect(string, pattern)
str_subset(string, pattern)
str_which(string, pattern)
9,分割字符串
str_split函数按照指定的模式分割字符串:
str_split(string, pattern, n = Inf, simplify = FALSE)
10,统计匹配模式的数量
str_count函数用于统计字符串中的指定字符的数量:
str_count(string, pattern = "")
11,替换字符
str_replace(string, pattern, replacement)
str_replace_all(string, pattern, replacement)
详细信息,请阅读stringr包的官方文档:Introduction to stringr
参考文档:
R学习笔记 第五篇:字符串操作的更多相关文章
- R学习笔记 第五篇:数据变换和清理
在使用R的分组操作之前,首先要了解R语言包,包实质上是实现特定功能的,预先写好的代码库(library),R拥有大量的软件包,许多包都是由某一领域的专家编写的,但并不是所有的包都有很高的质量的,在使用 ...
- C语言学习笔记 (008) - C语言字符串操作总结大全(超详细)(转)
1)字符串操作 strcpy(p, p1) 复制字符串 strncpy(p, p1, n) 复制指定长度字符串 strcat(p, p1) 附加字符串 strncat(p, p1, n) 附加指定长度 ...
- python学习笔记-(五)字符串&字典
1.字符串操作 >>> name = ("my name is cc")#首字母大写 >>> print(name.capitalize()) ...
- Django学习笔记第五篇--实战练习一--查询数据库并操作cookie
一.启动项目: django-admin start mysite1 cd mysite1 python manage.py startapp loginapp 根据上文敲命令就可以创建好了一个项目结 ...
- R学习笔记 第四篇:函数,分支和循环
变量用于临时存储数据,而函数用于操作数据,实现代码的重复使用.在R中,函数只是另一种数据类型的变量,可以被分配,操作,甚至把函数作为参数传递给其他函数.分支控制和循环控制,和通用编程语言的风格很相似, ...
- Go语言学习笔记(五)文件操作
加 Golang学习 QQ群共同学习进步成家立业工作 ^-^ 群号:96933959 文件读取 os.File 封装了文件相关操作 type File File代表一个打开的文件对象. func Cr ...
- R学习笔记 第三篇:数据框
数据框(data.frame)用于存储二维表(即关系表)的数据,每一列存储的数据类型必须相同,不同的数据列的数据类型可以相同,也可以不同,但是,每列的长度必须相同.数据框的每列可以有唯一的命名,在已创 ...
- python学习笔记(五)文件操作和集合
文件基本操作: 现有文件file.txt f=open('file.txt','r')#以只读方式打开一个文件,获取文件的句柄,如果是读的话,r可以不写,默认就是只读:文件不存在时,会报错 first ...
- ASP.NET Core 学习笔记 第五篇 ASP.NET Core 中的选项
前言 还记得上一篇文章中所说的配置吗?本篇文章算是上一篇的延续吧.在 .NET Core 中读取配置文件大多数会为配置选项绑定一个POCO(Plain Old CLR Object)对象,并通过依赖注 ...
随机推荐
- 项目发布Debug和Release版的区别
一.Debug和Release的区别 Debug:调试版本,包含调试信息,所以容量比Release大很多,并且不进行任何优化(优化会使调试复杂化,因为源代码和生成的指令间关系会更复杂),便于程序员调试 ...
- WPF自定义命令和处发命令
接实现ICommand接口的命令.在介绍之前,先看一下ICommand接口的原型: event EventHandler CanExecuteChanged; bool CanExecute(obje ...
- win10 uwp 使用 Geometry resources 在 xaml
经常会遇到在 xaml 使用矢量图,对于 svg 的矢量图,一般都可以拿出来写在 Path 的 Data ,所以可以写为资源,但是写出来的是字符串,如何绑定 Geometry 到字符串资源? 假如在资 ...
- PHP 页面静态化/纯静态化/伪静态化
个人博客迁移至独立博客:https://blog.plcent.com/,欢迎大家访问 概念 PHP静态化分为:纯静态化 和 伪静态化:纯静态化又分为:局部静态化 和 完全静态化 纯静态化:是把PHP ...
- 62、django之MTV模型(urls,view)
今天就进入到python最重要的阶段了django框架,框架就像胶水一样会将我们前面学的所有知识点粘合在一起,所以以前有哪些部分模糊的可以看看前面的随笔.本篇主要介绍djangoMTV模型,视图层之路 ...
- 使用脚本监控windows服务的方法
以下脚本可监控某一个windows服务,发现其停止就立即重启之. @echo off rem 定义循环间隔时间和监测的服务: set secs=60 set srvname="NetWin ...
- LeetCode 119. Pascal's Triangle II (杨辉三角之二)
Given an index k, return the kth row of the Pascal's triangle. For example, given k = 3,Return [1,3, ...
- angular 1.5.3各种模块使用(一)
1.angular cookie的用法:(1)引入angular-cookies(2)注入ngCookies这模块(3)想要更改cookies存储位置的话要添加内置服务$cookiesProvider ...
- WPF获得全局窗体句柄,并响应全局键盘事件
场景 wpf窗体运行后,只能捕获当前Active窗体的按键事件,如果要监听windows全局事件,并对当前窗口事件响应. 第一步:导入Winows API public class Win32 { [ ...
- Asp.net MVC4高级编程学习笔记-模型学习第五课MVC表单和HTML辅助方法20171101
MVC表单和HTML辅助方法 一.表单的使用. 表单中的action与method特性.Action表示表单要提交往那里,因此这里就有一个URL.这个URL可以是相对或绝对地址.表单默认的method ...