Я хочу, чтобы cout
выводил int с ведущими нулями, поэтому значение 1
будет напечатано как 001
, а значение 25
напечатано как 025
. Как я могу это сделать?
Как я могу дополнить int ведущими нулями при использовании оператора cout ‹
Ответы (7)
Со следующим,
#include <iomanip>
#include <iostream>
int main()
{
std::cout << std::setfill('0') << std::setw(5) << 25;
}
вывод будет
00025
setfill
по умолчанию установлен на пробел (' '
). setw
устанавливает ширину поля для печати, и все.
Если вам интересно узнать, как в целом форматировать выходные потоки, я написал ответ на другой вопрос, надеюсь, он будет полезен: Форматирование вывода консоли C ++.
char* or char[]
), а не в консоль напрямую. На самом деле я пишу функцию, которая возвращает форматированную строку
- person shashwat; 23.12.2012
<iostream>
и <iomanip>
в верхнюю часть файла, и вам нужно будет написать using namespace std;
, но это плохая практика, поэтому, возможно, вместо этого вам следует добавить к трем идентификаторам в этом ответе префикс std::
.
- person David Grayson; 06.07.2015
Другой способ добиться этого - использовать старую функцию 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
и заполнит пустые места.
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
В C ++ 20 вы сможете:
std::cout << std::format("{:03}", 25); // prints 025
А пока вы можете использовать библиотеку {fmt}, на основе std::format
.
Заявление об ограничении ответственности: я являюсь автором {fmt} и C ++ 20 std::format
.
Другой пример вывода даты и времени с использованием нуля в качестве символа заполнения для экземпляров однозначных значений: 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;
}
Я бы использовал следующую функцию. Мне не нравится 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;
}
char* or char[]
), а не в консоль напрямую. На самом деле я пишу функцию, которая возвращает форматированную строку
- person shashwat; 23.12.2012
std::stringstream
.
- person AraK; 23.12.2012
sprintf(s, "%02d-%02d-%04d", dd, mm, yy);
, где s
char*
, а dd, mm, yy
относятся к типу int
. Это запишет формат 02-02-1999
в соответствии со значениями в переменных.
- person shashwat; 23.12.2012