用前导零填充数字列
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
过去几个小时我一直在研究这个问题。我试过使用 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