使用FME生成特定长度的字段

原文发布时间:2013-11-18 11:11:46

作者:一辉

前面切切的十分钟的视频里面介绍了StringFormatter的转换器,用来生成特定格式的字段,再加上前面一篇讲FME对中文字符长度的博客,今天给大家介绍一个与此相关的一个应用,在中英文字符都包含的情情况下如何生成特定长度的字段,以生成一个记事本为例,源数据为一个xls表格内容如下图1:

 图1源数据的xls表格

要求记事本的形式如下图2:

图2要求的结果txt文件

首先我们试试StringFormatter这个转换器看能带给我们什么样的效果。第一个stringformatter2和stringformatter3分别将col_1和col_2进行格式化,再用stringconcatenator连接起来模板如图3:

图3使用StringFormatter的模板

得到结果如下图4:

图4使用StringFormatter得到结果图

这个结果显然不满足我们的要求,原因是col_2里面既有中文字符又有英文字符,中文字符本来应该占2个字符长度,而StringFormatter都认为占一个字符,所以得到上面的效果。

正确的方法是,1)首先使用pythoncaller计算出col_2的长度;2)新建一个字段,字段值赋值为空格;3)使用stringpadder将上一步生成的字段再加上特定长度(30-“第一步获得的长度度值”),然后再用stringcontatenator连接起来即可,详细设置见本文附件,模板如下图5。

图5正确方法

模板下载链接地址http://yunpan.cn/QUAySuj7QcItF

猜你喜欢

转载自blog.csdn.net/fmechina/article/details/81185806
今日推荐