我已经花了几个小时来研究这个问题。我尝试使用sprintf
,但它会将列更改为字符类型。我想要的只是一个固定宽度的数字列,并用零填充。
我已经花了几个小时来研究这个问题。我尝试使用sprintf
,但它会将列更改为字符类型。我想要的只是一个固定宽度的数字列,并用零填充。
如果你愿意使用自定义类,你可以编写一个打印方法来执行此操作。创建一个数据帧,并为它提供一个自定义类:
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
> cat(sprintf("%04d",5),"\n")
0005
## or
> print(sprintf("%04d",5),quote=FALSE)
[1] 0005
write.csv(...,quote=FALSE)
也许对您有所帮助
sprintf()
的用法了... - Ben Bolker