linux的shell修改文件某一列,Linux下awk命令shell脚本修改处理某一列数据方法实例...

问题描述:在用informatica从oracle数据库中导出数据生成文件后,发现其中一列数据导出格式有问题,本来字段为number型,我在PowerCenter Designer 的mapping中没有设置好类型转换,结果生成的文件中格式变成“xxx.000000000000000”。刚好这时候oracle中导出源表被同事清空了,没办法再重新导,这时候,只有想着用awk命令把文件处理一下,再上传ftp了。

修改前:

cd352e0f9c6fd7b2f0032dea619e8c99.gif

一共有两种方法可以将“xxx.000000000000000”转换成“xxx”。

方法一:

#!/bin/sh

cd /xx/xx/xx/xx

cat test.txt | awk -F ‘,’ ‘{split($2,a,”.”);split($4,b,”.”);print $1,a[1],$3,b[1],$5,$6}’ test.txt > test.txt2.txt

exit

备注:方法使用split()函数,将“xxx.000000000000000”分割成数组,split($2,a,”.”)中a代表分割后的数组名,以“.”号进行分割,然后在后面打印“a[1]”就是我想要的有用数据了。

方法二:

#!/bin/sh

cd /xx/xx/xx/xx

cat test.txt | awk -F ‘,’ ‘{print $1,int($2),$3,int($4),$5,$6}’ test.txt > test2.txt

exit

备注:此方法中,直接通过int()函数将数据强制转换成int型,这样后面的0就直接被去掉了,后面打印输出就可以了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值