从数据框中的列中删除小数

时间:2016-11-03 10:33:23

标签: r dataframe type-conversion

我的数据框中包含数字,这些数字是小数。我想删除列中的小数和蚂蚁整数。

我的数据框 expsrs 看起来像这样

ENSG00000226823.1           15     14.4947     22.5606     13.5819     5.09327     16.8503
ENSG00000266470.1            0           0           0           0           0           0
ENSG00000229435.2            0           0           0           0           0           0
ENSG00000277456.1            0           0           0           0           0           0
ENSG00000236077.2            0           0           0           0           0           0
ENSG00000280518.1            0     57.9833     30.4089     23.0059     4.85613           0

我尝试过这段代码,但它删除了小数,但也改变了值。

exprs$V1<-round(as.numeric(exprs$V1), 0)

我想从所有列中删除小数,但不从rownames中删除。有人可以帮忙吗?

2 个答案:

答案 0 :(得分:5)

一种选择是通过循环遍历列(lapply)来转换为exprs[] <- lapply(exprs, as.integer) exprs # v1 v2 v3 v4 v5 v6 #ENSG00000226823.1 15 14 22 13 5 16 #ENSG00000266470.1 0 0 0 0 0 0 #ENSG00000229435.2 0 0 0 0 0 0 #ENSG00000277456.1 0 0 0 0 0 0 #ENSG00000236077.2 0 0 0 0 0 0 #ENSG00000280518.1 0 57 30 23 4 0

exprs <- structure(list(v1 = c(15L, 0L, 0L, 0L, 0L, 0L), v2 = c(14.4947, 
0, 0, 0, 0, 57.9833), v3 = c(22.5606, 0, 0, 0, 0, 30.4089), 
v4 = c(13.5819, 
0, 0, 0, 0, 23.0059), v5 = c(5.09327, 0, 0, 0, 0, 4.85613), v6 = c(16.8503, 
0, 0, 0, 0, 0)), .Names = c("v1", "v2", "v3", "v4", "v5", "v6"
), class = "data.frame", row.names = c("ENSG00000226823.1", "ENSG00000266470.1", 
"ENSG00000229435.2", "ENSG00000277456.1", "ENSG00000236077.2", 
"ENSG00000280518.1"))

数据

{{1}}

答案 1 :(得分:0)

转换为整数时要非常小心,因为这会四舍五入。我在查找表时遇到了同样的问题,该表的所有值都为 xxx.5,我不想四舍五入 - 只需删除小数即可。 @Benjamin 的答案是正确的方法,即使用 floor()。