使用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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值