awk的printf格式化输出
20121108 Chenxin
cat sort_result.txt
223 浙江省
207 上海市
168 广东省
149 山东省
128 江苏省
114 云南省
111 四川省
需要将该文件中的第一个域求和,之后计算各个地区所占的百分比;
links_num=2000
awk -v links_num2=$links_num '{per=$1*100/links_num2} {printf("%-10d %4.3f%% %-10s\n",$1,per,$2)}' sort_result.txt|tee sort_resul
t_percent.txt
awk默认的print输出无法实现格式化;
使用printf进行格式化;
'{per=$1*100/links_num2} {printf("%-10d %4.3f%% %-10s\n",$1,per,$2)}'
per中保存的是百分比
%-10d:任意的格式前都以%开始,-代表左对齐,d代表是数值;左对齐输出10位宽带的数值;
%4.3f:4位整数宽带,小数点后保留3位
%%:表示输出一个%(第一个%为转义的意思)
之后有个tab键,也会被自动输出;
%-10s:左对齐输出10位字符串;
输出:
223 10.701% 浙江省
207 9.933% 上海市
168 8.061% 广东省
149 7.150% 山东省
128 6.142% 江苏省
114 5.470% 云南省
111 5.326% 四川省
106 5.086% 北京市
84 4.031% 湖北省
82 3.935% 重庆市
71 3.407% 河北省
66 3.167% 福建省
64 3.071% 安徽省
61 2.927% 湖南省
awk 中 printf 使用方法
20121112
printf()函数是格式化输出函数, 一般用于向标准输出设备按规定格式输出信息。在编写程序时经常会用到此函数。printf()函数的调用格式为:
printf("", );
其中格式化字符串包括两部分内容: 一部分是正常字符, 这些字符将按原样输出; 另一部分是格式化规定字符, 以"%"开始, 后跟一个或几个规定字符,用来确定输出内容格式。
参量表是需要输出的一系列参数, 其个数必须与格式化字符串所说明的输出参数个数一样多, 各参数之间用","分开, 且顺序一一对应, 否则将会出现意想不到的错误。
%d 十进制有符号整数
%u 十进制无符号整数
%f 浮点数
%s 字符串
%c 单个字符
%p 指针的值
%e 指数形式的浮点数
%x, %X 无符号以十六进制表示的整数
%0 无符号以八进制表示的整数
%g 自动选择合适的表示法
\n 换行
\f 清屏并换页
\r 回车
\t Tab符
\xhh 表示一个ASCII码用16进表示,其中hh是1到2个16进制数
说明:
(1). 可以在"%"和字母之间插进数字表示最大场宽。
例如: %3d 表示输出3位整型数, 不够3位右对齐。
%9.2f 表示输出场宽为9的浮点数, 其中小数位为2, 整数位为6,小数点占一位, 不够9位右对齐。
%8s 表示输出8个字符的字符串, 不够8个字符右对齐。
如果字符串的长度、或整型数位数超过说明的场宽, 将按其实际长度输出.但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出;若小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出.
另外, 若想在输出值前加一些0, 就应在场宽项前加个0。
例如: %04d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度为4位。
如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度,小数点前的数字代表最小宽度。
例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 则第9个字符以后的内容将被删除。
(2). 可以在"%"和字母之间加小写字母l, 表示输出的是长型数。
例如: %ld 表示输出long整数
%lf 表示输出double浮点数
(3). 可以控制输出左对齐或右对齐, 即在"%"和字母之间加入一个"-" 号可说明输出为左对齐, 否则为右对齐。
例如: %-7d 表示输出7位整数左对齐
%-10s 表示输出10个字符左对齐
例子:
df -h > dffile
more dffile
Filesystem Size Used Avail Use% Mounted on
/dev/hda1 15G 5.1G 8.7G 37% /
none 252M 0 252M 0% /dev/shm
/dev/hda6 31G 12G 18G 40% /home
/dev/hda3 15G 1.7G 13G 13% /usr
/dev/hda2 15G 152M 14G 2% /var
awk '{printf ("%12s\n",$1)}' dffile
Filesystem
/dev/hda1
none
/dev/hda6
/dev/hda3
/dev/hda2
awk '{printf ("%-12s\n",$1)}' dffile
Filesystem
/dev/hda1
none
/dev/hda6
/dev/hda3
/dev/hda2
例子:
echo 1.7 > 2
awk '{printf ("%d\n",$1)} 2
1
awk '{printf ("%f\n",$1)}' 2
1.700000
awk '{printf ("%3.1f\n",$1)}' 2
1.7
awk '{printf ("%4.1f\n",$1)}' 2
1.7
awk '{printf ("%e\n",$1)}' 2
1.700000e+00