当前位置:K88软件开发文章中心编程语言R语言R语言01 → 文章内容

R语言 数据帧

减小字体 增大字体 作者:佚名  来源:网上搜集  发布时间:2019-1-15 15:46:10

由 xiaoxiaogang 创建,陈 最后一次修改 2016-12-12 数据帧是表或二维阵列状结构,其中每一列包含一个变量的值,并且每一行包含来自每一列的一组值。以下是数据帧的特性。 列名称应为非空。 行名称应该是唯一的。 存储在数据帧中的数据可以是数字,因子或字符类型。 每个列应包含相同数量的数据项。 创建数据帧# Create the data frame.emp.data <- data.frame( emp_id = c (1:5), emp_name = c("Rick","Dan","Michelle","Ryan","Gary"), salary = c(623.3,515.2,611.0,729.0,843.25), start_date = as.Date(c("2012-01-01", "2013-09-23", "2014-11-15", "2014-05-11", "2015-03-27")), stringsAsFactors = FALSE)# Print the data frame.print(emp.data) 当我们执行上面的代码,它产生以下结果 - emp_id emp_name salary start_date1 1 Rick 623.30 2012-01-012 2 Dan 515.20 2013-09-233 3 Michelle 611.00 2014-11-154 4 Ryan 729.00 2014-05-115 5 Gary 843.25 2015-03-27获取数据帧的结构通过使用str()函数可以看到数据帧的结构。 # Create the data frame.emp.data <- data.frame( emp_id = c (1:5), emp_name = c("Rick","Dan","Michelle","Ryan","Gary"), salary = c(623.3,515.2,611.0,729.0,843.25), start_date = as.Date(c("2012-01-01", "2013-09-23", "2014-11-15", "2014-05-11", "2015-03-27")), stringsAsFactors = FALSE)# Get the structure of the data frame.str(emp.data)当我们执行上面的代码,它产生以下结果 - 'data.frame': 5 obs. of 4 variables: $ emp_id : int 1 2 3 4 5 $ emp_name : chr "Rick" "Dan" "Michelle" "Ryan" ... $ salary : num 623 515 611 729 843 $ start_date: Date, format: "2012-01-01" "2013-09-23" "2014-11-15" "2014-05-11" ...数据框中的数据摘要可以通过应用summary()函数获取数据的统计摘要和性质。 # Create the data frame.emp.data <- data.frame( emp_id = c (1:5), emp_name = c("Rick","Dan","Michelle","Ryan","Gary"), salary = c(623.3,515.2,611.0,729.0,843.25), start_date = as.Date(c("2012-01-01", "2013-09-23", "2014-11-15", "2014-05-11", "2015-03-27")), stringsAsFactors = FALSE)# Print the summary.print(summary(emp.data)) 当我们执行上面的代码,它产生以下结果 - emp_id emp_name salary start_date Min. :1 Length:5 Min. :515.2 Min. :2012-01-01 1st Qu.:2 Class :character 1st Qu.:611.0 1st Qu.:2013-09-23 Median :3 Mode :character Median :623.3 Median :2014-05-11 Mean :3 Mean :664.4 Mean :2014-01-14 3rd Qu.:4 3rd Qu.:729.0 3rd Qu.:2014-11-15 Max. :5 Max. :843.2 Max. :2015-03-27 从数据帧提取数据使用列名称从数据框中提取特定列。 # Create the data frame.emp.data <- data.frame( emp_id = c (1:5), emp_name = c("Rick","Dan","Michelle","Ryan","Gary"), salary = c(623.3,515.2,611.0,729.0,843.25), start_date = as.Date(c("2012-01-01","2013-09-23","2014-11-15","2014-05-11", "2015-03-27")), stringsAsFactors = FALSE)# Extract Specific columns.result <- data.frame(emp.data$emp_name,emp.data$salary)print(result)当我们执行上面的代码,它产生以下结果 - emp.data.emp_name emp.data.salary1 Rick 623.302 Dan 515.203 Michelle 611.004 Ryan 729.005 Gary 843.25先提取前两行,然后提取所有列# Create the data frame.emp.data <- data.frame( emp_id = c (1:5), emp_name = c("Rick","Dan","Michelle","Ryan","Gary"), salary = c(623.3,515.2,611.0,729.0,843.25), start_date = as.Date(c("2012-01-01", "2013-09-23", "2014-11-15", "2014-05-11", "2015-03-27")), stringsAsFactors = FALSE)# Extract first two rows.result <- emp.data[1:2,]print(result)当我们执行上面的代码,它产生以下结果 - emp_id emp_name salary start_date1 1 Rick 623.3 2012-01-012 2 Dan 515.2 2013-09-23用第2和第4列提取第3和第5行# Create the data frame.emp.data <- data.frame( emp_id = c (1:5), emp_name = c("Rick","Dan","Michelle","Ryan","Gary"), salary = c(623.3,515.2,611.0,729.0,843.25), start_date = as.Date(c("2012-01-01", "2013-09-23", "2014-11-15", "2014-05-11", "2015-03-27")), stringsAsFactors = FALSE)# Extract 3rd and 5th row with 2nd and 4th column.result <- emp.data[c(3,5),c(2,4)]print(result)当我们执行上面的代码,它产生以下结果 - emp_name start_date3 Michelle 2014-11-155 Gary 2015-03-27扩展数据帧可以通过添加列和行来扩展数据帧。 添加列只需使用新的列名称添加列向量。 # Create the data frame.emp.data <- data.frame( emp_id = c (1:5), emp_name = c("Rick","Dan","Michelle","Ryan","Gary"), salary = c(623.3,515.2,611.0,729.0,843.25), start_date = as.Date(c("2012-01-01", "2013-09-23", "2014-11-15", "2014-05-11", "2015-03-27")), stringsAsFactors = FALSE)# Add the "dept" coulmn.emp.data$dept <- c("IT","Operations","IT","HR","Finance")v <- emp.dataprint(v)当我们执行上面的代码,它产生以下结果 - emp_id emp_name salary start_date dept1 1 Rick 623.30 2012-01-01 IT2 2 Dan 515.20 2013-09-23 Operations3 3 Michelle 611.00 2014-11-15 IT4 4 Ryan 729.00 2014-05-11 HR5 5 Gary 843.2

[1] [2]  下一页


R语言 数据帧