R语言中的字符处理
2. 字符串连接
paste(..., sep = " ", collapse = NULL),其中collpase参数可将多个字符串连接成一个。
=====================================
3. 字符串分割
strsplit(x, split, extended = TRUE, fixed = FALSE, perl = FALSE)
=================================================================================
QWE <- c("QWERTYUIOPASDFGHJKLZXCVBNM")
> unlist(strsplit(QWE, ""))
[1] "Q" "W" "E" "R" "T" "Y" "U" "I" "O" "P" "A" "S" "D" "F" "G" "H" "J" "K" "L"
[20] "Z" "X" "C" "V" "B" "N" "M"
> xtest #将xtest表示化成小时为单位的时间表示形式,以便用于坐标轴显示
[1] "0:00:04" "0:53:18" "1:53:18" "2:53:17" "3:53:16" "4:53:16"
[7] "5:53:16" "6:53:16" "7:53:16" "8:53:16" "9:53:15" "10:53:14"
[13] "11:53:13" "12:53:13" "13:53:13" "14:53:13" "15:53:13" "16:53:13"
[19] "17:53:13" "18:53:13" "19:53:13" "20:53:13" "21:53:13" "22:53:13"
[25] "23:53:14"
> xtest <- as.data.frame(strsplit(xtest, split= ":"))
> xtest
c..0....00....04.. c..0....53....18.. c..1....53....18.. c..2....53....17..
1 0 0 1 2
2 00 53 53 53
3 04 18 18 17
c..3....53....16.. c..4....53....16.. c..5....53....16.. c..6....53....16..
1 3 4 5 6
2 53 53 53 53
3 16 16 16 16
c..7....53....16.. c..8....53....16.. c..9....53....15.. c..10....53....14..
1 7 8 9 10
2 53 53 53 53
3 16 16 15 14
c..11....53....13.. c..12....53....13.. c..13....53....13..
1 11 12 13
2 53 53 53
3 13 13 13
c..14....53....13.. c..15....53....13.. c..16....53....13..
1 14 15 16
2 53 53 53
3 13 13 13
c..17....53....13.. c..18....53....13.. c..19....53....13..
1 17 18 19
2 53 53 53
3 13 13 13
c..20....53....13.. c..21....53....13.. c..22....53....13..
1 20 21 22
2 53 53 53
3 13 13 13
c..23....53....14..
1 23
2 53
3 14
> mode(xtest)
[1] "list"
> xtest <- apply(xtest, c(1,2), as.numeric) # list --> numeric
> mode(xtest)
[1] "numeric"
> xtest <- apply(xtest, 2, function(x){x[1]+x[2]/60+x[3]/3600})
> xtest
c..0....00....04.. c..0....53....18.. c..1....53....18.. c..2....53....17..
0.01111111 0.93333333 1.93333333 2.93055556
c..3....53....16.. c..4....53....16.. c..5....53....16.. c..6....53....16..
3.92777778 4.92777778 5.92777778 6.92777778
c..7....53....16.. c..8....53....16.. c..9....53....15.. c..10....53....14..
7.92777778 8.92777778 9.92500000 10.92222222
c..11....53....13.. c..12....53....13.. c..13....53....13.. c..14....53....13..
11.91944444 12.91944444 13.91944444 14.91944444
c..15....53....13.. c..16....53....13.. c..17....53....13.. c..18....53....13..
15.91944444 16.91944444 17.91944444 18.91944444
c..19....53....13.. c..20....53....13.. c..21....53....13.. c..22....53....13..
19.91944444 20.91944444 21.91944444 22.91944444
c..23....53....14..
23.92222222
==================================================================================
3.2 按照特定长度截取
substr(x, start, stop)
substring(text, first, last = 1000000)
substr(x, start, stop) <- value
substring(text, first, last = 1000000) <- value
9, 2), seq(2, 10, 2))
[1] "ab" "cd" "ef" "gh" "ij"
===============================================================
4. 字符串替换及大小写转换
chartr(old, new, x)
4.2 正则替换
useBytes = FALSE)和gsub()可以进行正则替换,x表示字符向量。区别在于,sub()只替换第一个遇到,而gsub()替换其中所有。
tolower(x)
casefold(x, upper = FALSE)
其中,casefold()是S语言兼容函数,可以忽略。
5. 字符串匹配
grep(pattern, x, ignore.case = FALSE, extended = TRUE, perl = FALSE, value = FALSE, fixed = FALSE, useBytes = FALSE),grepl(),regexpr(),gregexpr(),regexec()函数是基本的字符匹配函,它们都可以匹配字符向量。
]{1, }。
}。
m}?,{n, }?。
'tolower', 'toupper' and 'chartr' for character translations.
'charmatch', 'pmatch', 'match'. 'apropos' uses regexps and has
nice examples.
stringr包
agrep()
参考:
1. http://cos.name/cn/topic/12987#post-12987
2. http://cos.name/cn/topic/104746
R语言中的字符处理的更多相关文章
- R+openNLP︱openNLP的六大可实现功能及其在R语言中的应用
每每以为攀得众山小,可.每每又切实来到起点,大牛们,缓缓脚步来俺笔记葩分享一下吧,please~ --------------------------- openNLP是NLP中比较好的开源工具,R语 ...
- R语言学习笔记1——R语言中的基本对象
R语言,一种自由软件编程语言与操作环境,主要用于统计分析.绘图.数据挖掘.R本来是由来自新西兰奥克兰大学的Ross Ihaka和Robert Gentleman开发(也因此称为R),现在由“R开发核心 ...
- R 语言中的数据结构
基本数据类型 6种 numaric 如 12, 12.4 integer 如 2L,0L complex 包含实数和虚数 如 3+2i character 要用双引号或者单引号包括起来 如 & ...
- R语言中的几种数据结构
R语言中的几种数据结构 一 R中对象的5种基本类型 字符(character) 整数 (integer) 复数(complex) 逻辑(logical:True/False) 数值(numeric: ...
- 【R语言入门】R语言中的变量与基本数据类型
说明 在前一篇中,我们介绍了 R 语言和 R Studio 的安装,并简单的介绍了一个示例,接下来让我们由浅入深的学习 R 语言的相关知识. 本篇将主要介绍 R 语言的基本操作.变量和几种基本数据类型 ...
- R语言中的正则表达式(转载:http://blog.csdn.net/duqi_yc/article/details/9817243)
转载:http://blog.csdn.net/duqi_yc/article/details/9817243 目录 Table of Contents 1 正则表达式简介 2 字符数统计和字符翻译 ...
- 机器学习:R语言中如何使用最小二乘法
详细内容见上一篇文章:http://www.cnblogs.com/lc1217/p/6514734.html 这里只是介绍下R语言中如何使用最小二乘法解决一次函数的线性回归问题. 代码如下:(数据同 ...
- R语言中的横向数据合并merge及纵向数据合并rbind的使用
R语言中的横向数据合并merge及纵向数据合并rbind的使用 我们经常会遇到两个数据框拥有相同的时间或观测值,但这些列却不尽相同.处理的办法就是使用merge(x, y ,by.x = ,by.y ...
- R语言中数据结构
R语言还是有点古老感觉,数据结构没有Python中那么好用.以下简单总结一下R语言中经常使用的几个数据结构. 向量: R中的向量能够理解为一维的数组,每一个元素的mode必须同样,能够用c(x:y)进 ...
随机推荐
- 《DevExpress》记录之TreeList
如这两幅图所示:如果要显示左边的竖线,需要设置 感谢 DoomGuards本节Dome下载地址:http://pan.baidu.com/s/1wBOJk 密码:vz4d
- 《程序员代码面试指南》第三章 二叉树问题 Tarjan算法与并查集解决二叉树节点间最近公共祖先的批量查询问题
题目待续.... Tarjan算法与并查集解决二叉树节点间最近公共祖先的批量查询问题 java代码
- linux下无线鼠标驱动执行流程
操作系统: debian 7.4(linux 3.2.54) 硬件: 一个无线鼠标.一个有线鼠标.usb集线器. 从淘宝上花了15块钱买了个无线鼠标,很好奇它的驱动程序是如何执行的. 首先将usb集线 ...
- [算法]去掉字符串中连续出现的k个0子串
题目: 给定一个字符串str和一个整数k,如果str中正好有k个‘0’字符出现时,把k个连续的‘0’字符去除,返回处理后的字符串. 举例: str=”A00B”,k=2,返回“AB” str=”A00 ...
- MHA高可用集群安装配置
4台服务器 192.168.136.128 主 192.168.136.129 从 192.168.136.130 从 192.168.136.131 管理服务器 一主2从,一管理,安装mysql并配 ...
- Spring Cloud之Feign客户端调用工具
feign介绍 Feign客户端是一个web声明式http远程调用工具,提供了接口和注解方式进行调用. Spring Cloud 支持 RestTemplate Fetin Feign客户端实际开发 ...
- C/C++ 库函数 是否调用 WinAPI
1. 跟了一个函数 fopen,简单测试代码为: #include<stdio.h> #define F_PATH "e:\\Z.txt" int main(void) ...
- linux 新建分区 、格式化 并挂载的命令
一.新建分区命令为 fdisk /dev/diskname fdisk命令为交互式命令 p:显示当前硬盘上的分区,包括没保存的改动 n:创建新分区 e:表示扩扩展分区 p:表示主分区 d:删除一个分区 ...
- C语言链表结构体(学习笔记)
#include <stdio.h> #define LENTEST 100 // 采取逐步删除的方法求的素数 //先假设1-100都是素数,然后剔除2的倍数, //3的倍数,直到剔除所有 ...
- wiredtiger存储引擎介绍——本质就是LSM,当然里面也可以包含btree和列存储
见:http://www.slideshare.net/profyclub_ru/4-understanding-and-tuning-wired-tiger-the-new-high-perform ...
转载▼