问题描述:在用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就直接被去掉了,后面打印输出就可以了。

Logo

更多推荐