数据

1、三种常见的清洗数据

1)重复值数据

定义:把数据结构中,行数据相同的剔除

unique 函数语法: unique (x)

案例:

导入csv数据: data <- read.csv ( "sales.csv")

删除重复数据: new_data1 <- unique (data ) ? ---删除的为所有字段均重复的记录行

2)缺失值数据

处理方式:

数据补齐

删除对应缺失行

na.omit 函数作用:剔除数据结构中值为空(即缺失值以NA表示)的数据

na.omit 函数语法: na.omit (x)

案例: new_data2 <- na.otmi (data)

不处理

3)空格值数据

trim 函数作用:清除字符型数据前后的空格

trim 函数语法: trim (x)

案例: new_data3 <- trim (data)

注:trim 函数来自 raster包,使用前,先使用 install.packages("raster") 安装,再使用 library (raster) 引入该包;

数据基础

1、常见的三种数据类型

1)逻辑型(Logical):TRUE/FALSE

2)数值型(Numeric)

3)字符型(Character)

2

2、所有的对象都有两个属性:

1)类型: mode (x)

2)长度: length (x)

3

3、常用的两种数据结构

1)向量(Vertor)

定义:通过 c()函数来定义

限制:一个向量只允许存放一种数据类型

访问:通过方括号内的索引值(位置值)来访问数据

2)数据框(Frame)

定义:通过 data.frame()函数来定义

限制:一列只允许存放一种数据类型

访问:通过方括号内的行列位置值来访问数据

可视化编辑工具(函数): fix (data.frame)

数据导出

1、导出文本文件

1)write.table函数语法:

write.table (x, file ="", sep ="", row.names =TRUE, col.names =TRUE, quote =TRUE)

x:需要导出的数据

file:导出的文件路径

sep:分隔符,默认为空格(" "),也就是以空格为分割列

row.names:是否导出行序号,默认为TRUE,也就是导出行序号

col.names:是否导出列名,默认为TRUE,也就是导出列名

quote:字符串是否使用引号表示,默认为TRUE,也就是使用引号表示

2

2)案列:

先生成一个数据框(生成数据?。?/p>

age <- c (22,23)

name <- c ("ken", "john")

f <- data.frame (age, name)

再导出数据框数据(导出数据!)

write.table (f, file ="f.csv") ? ?---以空格分隔数据列(默认),含行号(默认),含列名(默认),字符串带引号

write.table (f,file ="f.csv", sep =",") ? ?---以逗号分隔数据列,含行号(默认),含列名(默认),字符串带引号

write.table (f,file ="f.csv", sep =",", row.names = FALSE) ? ?---以逗号分隔数据列,不含行号,含列名(默认),字符串带引号

write.table (f,file ="f.csv", row.names = FALSE, col.names =FALSE) ? ?---以空格分隔数据列,不含行号,不含列名,字符串带引号

write.table (f,file ="f.csv", row.names = FALSE, col.names =FALSE, quote =FALSE) ? ?---以空格分隔数据列,不含行号,不含列名,字符串不带引号

数据导入

1、导入 CSV文件

1)使用 read.csv函数导入CSV文件

2)read.csv函数语法: read.csv (file)

3)案例: data1 <- read.csv ("D:/data/datatable.csv") ? ?--绝对路径

2

2、导入文本文件

1)使用 read.table函数导入CSV文件

2)read.table函数语法: read.table (file, header = FALSE, sep="", …)

file:文件路径

header:文件标题行(文件头),默认为 FALSE,表示没有标题行

sep:分隔符,默认为空,表示默认把数据导入成一列

3)案例

data2 <- read.table ("D:/data/datatable.csv", header = TRUE, sep ="," )

data3 <- read.csv ("D:/data/datatable.csv", header = TRUE, sep ="," )

4)导入数据

read.table(file.choose())

3、导入 Excel文件

1) Excel文件导入步骤(x86操作系统)

引入 RODBC包

install.packages ("RODBC")

library (RODBC)

library(RODBC)

db <- odbcConnect(dsn="buobserv", uid="buobserv", pwd="buobserv", believeNRows=FALSE )

shop = sqlQuery(db, "select * from BAIDU_WAIMAI_SHOP_20161110")

注:安装包时,包名需要加引号,而引入包时不加引号!

使用 odbcConnectExcel函数来连接 Excel 2003(后缀名为 .xls)

odbcConnectExcel函数语法:?odbcConnectExcel?(file)

案例: connect1 <- odbcConnectExcel?("D:/data/datatable.xls")

使用 odbcConnectExcel2007函数来连接 Excel 2007(后缀名为 .xlsx)

odbcConnectExcel函数语法:?odbcConnectExcel2007?(file)

案例: connect2 <- odbcConnectExcel?("D:/data/datatable.xlsx")

使用 sqlFetch函数来读取 Excel中的 Sheet数据

sqlFetch函数语法: sqlFetch (connectname, Sheetname)

案例:data4 <- sqlFetch (connect1, "datasheet")

使用 odbcClose函数关闭 R和 Excel的连接

odbcClose函数语法: odbcClose (connectname)

案例:?odbcClose (connect1)

2)Excel文件导入步骤(x64操作系统)

引入 XLConnect包(需安装JDK程序)

使用 loadworkbook函数来加载 Excel文件

loadworkbook函数语法: loadworkbook (file)

案例: connect3 <- loadworkbook ("D:/data/datatable.xls")

使用 readworksheet函数来读取 Excel文件数据

readworksheet函数语法: readworksheet (connectname, Sheetname)

案例: data5 <- readworksheet (connect1, "datasheet")

数据抽取

1、常见的四种数据抽取方式:

1)字段抽取(字符抽?。?/p>

字段截取函数: substr (x, start, stop) ? ?---此函数语法规则类似Excel中的 mid函数

x:需要处理的字段/字符

start:开始位置

stop:结束位置

案例:

导入csv数据: data <- read.csv ("sales.csv")

截取指定字段:firstname <- substr (data[,1],1,1) ? ?---取 data表第一列字段的第一个字符(从第一个开始到第一个结束)

组合新数据:new_data1 <- data.frame (firstname, data) ? ---将新提取的 firstname字段放置在原表 data的第一列组合成新表 new_data1

2)字段拆分

字段分割函数: str_split_fixed (x, split, n)

x:需要处理的字段/字符

split:用于分割的字符串

n:分隔为多少列

返回值: data.frame

注:str_split_fixed 函数使用前,先使用 install.packages (stringr) 安装,再使用 library?(stringr)?引用该包

案例1(单行数据):

item <- "Apple iPad mini MF432CH/A 7.9英寸平板电脑 (16G WiFi版)深空灰定制版" ? ---商品名称

band <- str_split_fixed (item, " ", n=2) ? ?---截取商品名称 item中的品牌,以空格分割,分为2列

案例2(多行数据):

items <- read.csv ('sales.csv', stringsAsFactors = FALSE, fileEncoding='utf-8') ? ?---字符串是否转换为因子格式

bands <- str_split_fixed (items[, 1], " ", n=2) ? ?---运行结果以数据框结构形式体现----比较重要

new_items <- data.frame (bands[,1], items) ? ?---将截取出的 bands表第1列品牌与原表 item组合成新表 new_items表

3)记录抽取

记录抽取函数: subset (x, condition)

x:需要处理的数据

condition:过滤条件

返回值: data.frame

案例:

items <- read.table('sales.csv', sep="|", header=TRUE, fileEncoding='utf-8', stringsAsFactors=FALSE)

sub_items <- subset(items, comments>10000) ? ?---提取 comments大于10000的记录

2

4)随机抽样

随机抽样函数: sample (length, size, replace = FASLE)

length:样本长度

size:抽样行数

replace:是否可回收样本,默认为不放回,即FALSE

返回值:行数的位置值数组

案例:

items <- read.csv ('sales.csv') ? ? ---导入数据

rows <- nrow (items) ? ?---数据记录行,即抽样行数length

indexes <- sample (rows, 3, replace =TRUE) ? ?---使用 sample函数,在 rows(10行)抽取3个数据(抽取的是数据行位置行号)

data1 <- items [indexes, ] ? ?---提取

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

推荐阅读更多精彩内容