c++的格式化輸出
阿新 • • 發佈:2019-02-14
前言
在c++中通過格式化輸出的庫主要是iomanip
主要是對cin,cout之類的一些操縱運運算元,比如setfill,setw,setbase,setprecision等等。它是I/O流控制標頭檔案,就像C裡面的格式化輸出一樣.以下是一些常見的控制函式的:
dec 置基數為10 相當於"%d"
hex 置基數為16 相當於"%X"
oct 置基數為8 相當於"%o"
setfill( 'c' ) 設填充字元為c
setprecision( n ) 設顯示有效數字為n位
setw( n ) 設域寬為n個字元
這個控制符的意思是保證輸出寬度為n。如:
cout << setw( 3 ) << 1 << setw( 3 ) << 10 << setw( 3 ) << 100 << endl;
輸出結果為:
_ _1_10100 (預設是右對齊)當輸出長度大於3時(<<1000),setw(3)不起作用。
詳細說明
setw(n)用法: 通俗地講就是預設寬度
cout<<setw(5)<<255<<endl;
結果是:
(空格)(空格)255
setfill(char c) 用法 : 就是在預設寬度中如果已存在沒用完的寬度大小,則用設定的字元c填充
cout<<setfill(‘@‘)<<setw(5)<<255<<endl;
結果是:
@@255
注意:setw只作用於緊隨其後的部分,eg:
cout<<setfill('*')<<setw(6)<<123<<456;
執行結果為
***123456
這裡setfill('*')<<setw(6)只對 123 起作用輸出了***123,456
setbase(int n) : 將數字轉換為 n 進位制.
如
cout<<setbase(8 )<<setw(5)<<255<<endl;
cout<<setbase(10)<<setw(5)<<255<<endl;
cout<<setbase(16)<<setw(5)<<255<<endl;
結果是:
(空格)(空格)377
(空格)(空格) 255
(空格)(空格)(空格) f f
setprecision(long f)方法的用法
使用setprecision(n)可控制輸出流顯示浮點數的數字個數。C++預設的流輸出數值有效位是6。
如果setprecision(n)與setiosflags(ios::fixed)合用,可以控制小數點右邊的數字個數。setiosflags(ios::fixed)是用定點方式表示實數。
如果與setiosflags(ios::scientific)合用, 可以控制指數表示法的小數位數。setiosflags(ios::scientific)是用指數方式表示實數。
setiosflags(ios::fixed) 固定的浮點顯示
setiosflags(ios::scientific) 指數表示
setiosflags(ios::left) 左對齊
setiosflags(ios::right) 右對齊
setiosflags(ios::skipws) 忽略前導空白
setiosflags(ios::uppercase) 16進位制數大寫輸出
setiosflags(ios::lowercase) 16進位制小寫輸出 //VS2010中該方法已不使用,意外使用顯示沒有該成員錯誤。
setiosflags(ios::showpoint) 強制顯示小數點
setiosflags(ios::showpos) 強制顯示符號
例項程式碼
#include <iostream>
#include <iomanip>
using namespace std;
int main() {
int a = 12345;
double f = 123.4567;
//預設輸出整數
cout << "a=" << a << "===" << endl;
//佔8格,右對齊
cout << "a=" << setw(8) << a << "===" << endl;
//佔8格,左對齊
cout << "a=" << setw(8) << setiosflags(ios::left)
<< a << "===" << endl;
//預設輸出浮點數,有效位數顯示6位
cout << "f=" << f << "===" << endl;
//佔10格,小數顯示2位,右對齊
cout << "f=" << setw(10) << setprecision(2)
<< setiosflags(ios::fixed) << setiosflags(ios::right)
<< f << "===" << endl;
return 0;
}
c語言格式化
#include <stdio.h>
int main() {
int a = 12345;
double f = 123.4567;
//預設輸出整數
printf("a=%d===\n", a);
//佔8格,右對齊
printf("a=%8d===\n", a);
//佔8格,左對齊
printf("a=%-8d===\n", a);
//預設輸出浮點數,小數顯示6位
printf("f=%f===\n", f);
//佔10格,小數顯示2位,右對齊
printf("f=%10.2f===\n", f);
//佔10格,小數顯示2位,左對齊
printf("f=%-10.2f===\n", f);
return 0;
}