内容简介:在写shell脚本时,会遇到要把一个符点数转换成整数的情况。之前线上一个shell脚本在用awk从文本中读取出一个带两位小数的符点数后,是直接把它乘以100转换成整数的。脚本一直运行正常,直到后面遇到了一个符点数有两种方法可以解决这个问题:1通过
在写 shell 脚本时,会遇到要把一个符点数转换成整数的情况。之前线上一个shell脚本在用awk从文本中读取出一个带两位小数的符点数后,是直接把它乘以100转换成整数的。脚本一直运行正常,直到后面遇到了一个符点数 19004.44
,它在乘以100后得到的不是 1900444
而是科学记数 1.90044e+06
,导致导入数据库失败。后面测试发现符点数 19004.42
也存在同样的问题,如果下图所示:
1 解决方法
有两种方法可以解决这个问题:1通过 sub
或者 gsub
函数把符点数的小数点去掉;2和C/C++那样通过 printf
占位符格式化。
测试结果如下所示:
# Description: awk中符点型小数去掉小数点转换成整数的方法 # (c) 2018.03.28 vfhky https://typecodes.com/linux/awkdecimaltoint1.html #### 方法一:使用sub函数进行替换(把小数点去掉) [vfhky@typecodes shell]$ echo 19004.44 | awk '{sub(/\./,"",$1); print $1}' 1900444 [vfhky@typecodes shell]$ echo 0.44 | awk '{sub(/\./,"",$1); print $1}' 044 #### 小数点前面的0可以通过int函数强制转换去掉 [vfhky@typecodes shell]$ echo 0.44 | awk '{sub(/\./,"",$1); print int($1)}' 44 [vfhky@typecodes shell]$ #### 方法二:使用printf函数格式化 [vfhky@typecodes shell]$ echo 19004.44 | awk '{printf("%.0f\n", 100*$1)}' 1900444 [vfhky@typecodes shell]$ echo 0.44 | awk '{printf("%.0f\n", 100*$1)}' 44 [vfhky@typecodes shell]$ exit 0 |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- objective-c – NSDecimalNumber的小数部分
- 可以在MySQL中存储小数(22,2)的钱吗?
- 正则表达式判定保留2位小数的实现代码
- 在JSP中使用formatNumber控制要显示的小数位数方法
- 代码片段之jQuery控制input只能输入数字和两位小数
- JavaScript运算出现很多小数导致运算不精确的问题,用toFixed解决
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
创投之巅——中国创投精彩案例
投资界网站 / 人民邮电出版社 / 2018-11 / 69.00
中国的科技产业发展,与创投行业密不可分。在过去的几十年间,资本与科技的结合,缔造了众多创业“神话”。回顾这些科技巨头背后的资本路径,可以给如今的国内创业者很多有益的启发。 本书从风险投资回报率、投资周期、利润水平、未来趋势等多个维度,筛选出了我国过去几十年中最具代表性的创业投资案例,对其投资过程和企业成长过程进行复盘和解读,使读者可以清晰地看到优秀创业公司的价值与卓越投资人的投资逻辑。一起来看看 《创投之巅——中国创投精彩案例》 这本书的介绍吧!