Как я могу дополнить int начальными нулями при использовании оператора cout <<? - PullRequest
226 голосов
/ 11 ноября 2009

Я хочу, чтобы cout выводил целое число с начальными нулями, поэтому значение 1 будет напечатано как 001, а значение 25 будет напечатано как 025. Как я могу это сделать?

Ответы [ 6 ]

332 голосов
/ 11 ноября 2009

Сначала включите <iomanip>, затем:

cout << setfill('0') << setw(5) << 25;

output:
00025

setfill по умолчанию установлено на space ' '. setw устанавливает ширину поля для печати и все.


Если вам интересно узнать, как вообще форматировать выходные потоки, я написал ответ на другой вопрос, надеюсь, это будет полезно: Форматирование вывода на C ++.

39 голосов
/ 23 декабря 2012

Другой способ достижения этого - использование старой printf() функции языка C

Вы можете использовать это как

int dd = 1, mm = 9, yy = 1;
printf("%02d - %02d - %04d", mm, dd, yy);

Это напечатает 09 - 01 - 0001 на консоли.

Вы также можете использовать другую функцию sprintf() для записи форматированного вывода в строку, как показано ниже:

int dd = 1, mm = 9, yy = 1;
char s[25];
sprintf(s, "%02d - %02d - %04d", mm, dd, yy);
cout << s;

Не забудьте включить в вашу программу заголовочный файл stdio.h для обеих этих функций

Что следует отметить:

Вы можете заполнить пробел либо 0, либо другим символом (не числом).
Если вы напишите что-то вроде %24d спецификатора формата, это не заполнит 2 пробелами. Это установит pad на 24 и заполнит пробелы.

30 голосов
/ 12 октября 2014
cout.fill('*');
cout << -12345 << endl; // print default value with no field width
cout << setw(10) << -12345 << endl; // print default with field width
cout << setw(10) << left << -12345 << endl; // print left justified
cout << setw(10) << right << -12345 << endl; // print right justified
cout << setw(10) << internal << -12345 << endl; // print internally justified

Это производит вывод:

-12345
****-12345
-12345****
****-12345
-****12345
17 голосов
/ 11 ноября 2009
cout.fill( '0' );    
cout.width( 3 );
cout << value;
3 голосов
/ 15 марта 2013

Я бы использовал следующую функцию. Мне не нравится sprintf; это не делает то, что я хочу !!

#define hexchar(x)    ((((x)&0x0F)>9)?((x)+'A'-10):((x)+'0'))
typedef signed long long   Int64;

// Special printf for numbers only
// See formatting information below.
//
//    Print the number "n" in the given "base"
//    using exactly "numDigits".
//    Print +/- if signed flag "isSigned" is TRUE.
//    Use the character specified in "padchar" to pad extra characters.
//
//    Examples:
//    sprintfNum(pszBuffer, 6, 10, 6,  TRUE, ' ',   1234);  -->  " +1234"
//    sprintfNum(pszBuffer, 6, 10, 6, FALSE, '0',   1234);  -->  "001234"
//    sprintfNum(pszBuffer, 6, 16, 6, FALSE, '.', 0x5AA5);  -->  "..5AA5"
void sprintfNum(char *pszBuffer, int size, char base, char numDigits, char isSigned, char padchar, Int64 n)
{
    char *ptr = pszBuffer;

    if (!pszBuffer)
    {
        return;
    }

    char *p, buf[32];
    unsigned long long x;
    unsigned char count;

    // Prepare negative number
    if (isSigned && (n < 0))
    {
        x = -n;
    }
    else
    {
        x = n;
    }

    // Set up small string buffer
    count = (numDigits-1) - (isSigned?1:0);
    p = buf + sizeof (buf);
    *--p = '\0';

    // Force calculation of first digit
    // (to prevent zero from not printing at all!!!)
    *--p = (char)hexchar(x%base);
    x = x / base;

    // Calculate remaining digits
    while(count--)
    {
        if(x != 0)
        {
            // Calculate next digit
            *--p = (char)hexchar(x%base);
            x /= base;
        }
        else
        {
            // No more digits left, pad out to desired length
            *--p = padchar;
        }
    }

    // Apply signed notation if requested
    if (isSigned)
    {
        if (n < 0)
        {
            *--p = '-';
        }
        else if (n > 0)
        {
            *--p = '+';
        }
        else
        {
            *--p = ' ';
        }
    }

    // Print the string right-justified
    count = numDigits;
    while (count--)
    {
        *ptr++ = *p++;
    }
    return;
}
0 голосов
/ 15 июня 2017

Другой пример вывода даты и времени с использованием нуля в качестве символа заполнения в случаях однозначных значений: 2017-06-04 18: 13: 02

#include "stdafx.h"
#include <iostream>
#include <iomanip>
#include <ctime>
using namespace std;

int main()
{
    time_t t = time(0);   // Get time now
    struct tm * now = localtime(&t);
    cout.fill('0');
    cout << (now->tm_year + 1900) << '-'
        << setw(2) << (now->tm_mon + 1) << '-'
        << setw(2) << now->tm_mday << ' '
        << setw(2) << now->tm_hour << ':'
        << setw(2) << now->tm_min << ':'
        << setw(2) << now->tm_sec
        << endl;
    return 0;
}
...