用前导零填充数字列

pad numeric column with leading zeros

过去几个小时我一直在研究这个问题。我试过使用 sprintf 但它会将列更改为字符。我想要做的就是有一个固定宽度的数字列,用零填充。

如果您提供更多背景信息,我们也许可以帮助您解决最终(而不是近端)问题,例如如果您需要 output 这种格式但不带引号:

> cat(sprintf("%04d",5),"\n")
0005 
## or
> print(sprintf("%04d",5),quote=FALSE)
[1] 0005

write.csv(...,quote=FALSE) 也可能有帮助

如果您愿意使用自定义 class,您可以编写执行此操作的打印方法。制作一个数据框,并给它一个自定义 class:

DF <- data.frame(a=letters[1:10], b=sample(c(1, 10, 100), 10, rep=T), c=sample(c(1, 10, 100), 10, rep=T))
class(DF) <- c("my_df", class(DF))

编写一个使用@BenBolker 格式的打印方法:

print.my_df <- function(x, ...) {
  num.cols <- sapply(x, is.numeric)
  x[num.cols] <- lapply(x[num.cols], sprintf, fmt="%04d")
  NextMethod()
}

然后:

DF

产生:

   a    b    c
1  a 0100 0100
2  b 0010 0001
3  c 0001 0010
4  d 0001 0100
5  e 0001 0001
6  f 0001 0001
7  g 0001 0001
8  h 0001 0100
9  i 0001 0100
10 j 0001 0001

您仍然可以以相同的方式使用数据框,因为数字仅在打印时进行转换。

> sum(DF$b)
[1] 118