首页 » 编程开发 » Informatica » 正文

Linux下awk命令shell脚本修改处理某一列数据方法实例

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

修改前:

1

一共有两种方法可以将“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就直接被去掉了,后面打印输出就可以了。

 

发表评论