我有一个看起来有点像这样的数据文件:
Analyte Value
Fe 60.3203
Sio2 2.3003
As 0.5564我希望将value列四舍五入到不同的小数位置,这取决于它的值。也就是说,如果值>1,那么我想显示2小数位,如果它是<1,我想把小数位圈到小数点3位,那么可以将它应用到R数据吗?
我试过:
df$value <- if_else(df$value >1.0, round(df$value, digits =3), round(df$value, digits =2))和
df$value <- if_else(df$value >1.0, format(round(df$value, nsmall =3)), format(round(df$value, nsmall =2)))我还尝试了上述两个选项的几个变体,但最后我总是将整列舍入到相同的小数位数。
我怀疑这种类型更适合在显示表时使用某种图形类型的特性?
发布于 2020-10-16 06:13:07
如果是为了显示目的,可以使用sprintf来控制小数位:
with(df, ifelse(Value > 1, sprintf("%.3f",Value), sprintf("%.2f",Value)))
#[1] "60.320" "2.300" "0.56" 您与format和round关系密切,您可以:
with(df, trimws(ifelse(Value > 1, format(round(Value, 3), nsmall = 3),
format(round(Value, 2), nsmall = 2))))https://stackoverflow.com/questions/64383727
复制相似问题