我试图找到一个好方法打印前导0,如01001邮政编码。当这个数字被存储为1001时,什么是一个好方法呢?

我想过使用case语句或if来计算出数字是多少位,然后将其转换为带有额外0的字符数组进行打印,但我不禁想,可能有一种方法可以用printf格式语法来做到这一点,这是逃避我的。


当前回答

如果将ZIP Code存储为字符串(它是字符串),而不是存储为数字(它不是字符串),您将为自己节省大量麻烦(长期而言)。

其他回答

如果你需要将邮政编码存储在字符数组zipcode[]中,你可以使用这个:

snprintf(zipcode, 6, "%05.5d", atoi(zipcode));

Printf允许各种格式选项。

例子:

printf("leading zeros %05d", 123);
printf("%05d", zipCode);

0表示填充的内容,5表示整数的宽度。

例1:如果使用“%02d”(用于日期),则只会为个位列中的数字填充零。例如,用06代替6。

例2:“%03d”将为个位列中的一个数字填充2个零,为十位列中的一个数字填充1个零。例如,数字7被填充到007,数字17被填充到017。

更灵活的. . 下面是一个示例,打印具有固定宽度和空格填充的右对齐数字行。

//---- Header
std::string getFmt ( int wid, long val )
{  
  char buf[64];
  sprintf ( buf, "% *ld", wid, val );
  return buf;
}
#define FMT (getFmt(8,x).c_str())

//---- Put to use
printf ( "      COUNT     USED     FREE\n" );
printf ( "A: %s %s %s\n", FMT(C[0]), FMT(U[0]), FMT(F[0]) );
printf ( "B: %s %s %s\n", FMT(C[1]), FMT(U[1]), FMT(F[1]) );
printf ( "C: %s %s %s\n", FMT(C[2]), FMT(U[2]), FMT(F[2]) );

//-------- Output
      COUNT     USED     FREE
A:      354   148523     3283
B: 54138259 12392759   200391
C:    91239     3281    61423

函数和宏的设计使打印文件更具可读性。

如果将ZIP Code存储为字符串(它是字符串),而不是存储为数字(它不是字符串),您将为自己节省大量麻烦(长期而言)。