Excel到EDI报文转换代码详解

EDI目前已广泛应用于电子、物流、汽车、零售等行业。

越来越多的交易伙伴要求建立EDI连接,通过EDI来对接上下游交易伙伴,收发业务单据。

当我们与新的交易伙伴建立EDI连接时,有多种实施方案可供选择,如果企业的单据量较少,预算也不多的话,Excel方案相对来说就比较适合了。

本文章主要给大家讲解当企业自主实施时,如何写将Excel转换为对应报文的代码。

以856发货通知为例:

一.搭建工作流

856属于X12报文,知行之桥系统的X12端口可以将X12报文转成对应的报文格式的XML文件,也可以将报文格式的XML文件转为对应的X12报文,即可以进行报文到XML文件的双向转换。 由X12端口生成的XML文件是固定格式的,所以我们只需要将Excel转换为目标XML文件,然后通过X12端口将该XML文件转换为对应报文即可。

根据上述需求,可搭建如下工作流:

Excel_Translate1.png

二.使用规范中的示例856报文通过X12端口生成目标XML文件

Excel_Translate2.png Excel_Translate3.png

 下载示例报文和生成的XML文件

示例报文可参考如下解析进行阅读:

三.根据实际业务需求设计Excel模版

根据客户提供的规范整理对应的Mapping,然后参考Mapping和目标XML文件设计856的Excel模版如下图:

Excel_Translate4.png

 下载示例模版

四.写转换代码

拿到目标XML文件,设计好Excel模版,就可以写代码了

1.进入Excel端口的文件目录,可以看到如下几个模版文件

Excel_Translate5.png

2.选择Sample_XLSX_To_XML_Template.xml文件打开,可以看到如下示例代码

代码前半部分从Excel中取值,后半部分将取到的业务值写入目标XML中。

Excel_Translate6.png

 下载示例代码

3.从Excel中进行取值

根据实际需求参考上方示例代码从Excel表中进行取值,如下图所示:

Excel_Translate7.png

其余业务字段亦按照如上规律进行取值。

4.将取到的值写入目标XML

首先需要将目标XML放入代码的后半部分,注意只需要用TransactionSet部分代替示例代码中的TransactionSet部分。

然后就可以根据规范或者整理好的Mapping将从Excel模版中取到的值写入目标XML的对应位置。

a.非数组字段取值方式: [data.字段名 | def | trim | xmlencode]

如下图所示:

Excel_Translate8.png

def、trim等格式化器可在如下网址中查询使用方法,然后根据实际需求使用

扩展阅读

注意:在Excel生成报文的代码中,每个字段取值时都必须使用xmlencode格式化器

Excel_Translate9.png

b.数组字段取值方式[data.字段名#[_index] | def | trim | xmlencode]

如下图所示

Excel_Translate10.png

对于数组数据,需要对数组字段值进行遍历读取,本代码使用enum关键字对buyer_item_no数组字段进行遍历,通过[_index]拿到下标,然后根据下标取出其它数组字段

扩展阅读:enum关键字的使用方法

本项目遍历的条件是该行的buyer_item_no值不为空。

Excel_Translate.jpg

HL01是层级编号,Item的层级编号从2开始递增,所以需要设置一个临时字段,每读取一行item,则自增一下:

c.以;隔开的序列号字段的取值

Excel_Translate11.png

先设置一个临时字段取出该行的序列号值,然后通过enum的separator参数取出

扩展阅读:enum关键字的使用方法

d.对于必填字段的检查

Excel_Translate12.png

扩展阅读:

check关键字
throw关键字
else关键字

e.对于非必填字段,如果没有值则需要跳过整个segment

Excel_Translate13.png

使用check关键字跳过即可

f.对于生成的XML文件进行改名

可以将发货通知编号以及当前日期放在文件名上方便有问题时进行检查

Excel_Translate14.png

g.完整代码见如下附件

 下载示例代码

5.测试代码

打开Excel端口,选择转换模式为Template,然后上传写好的代码文件

Excel_Translate15.png Excel_Translate16.png

在输入处上传要转换的856Excel文件并发送

Excel_Translate17.png

从X12端口的输出处即可拿到生成的报文文件

Excel_Translate18.png

了解更多 EDI 信息,请您通过邮件 sales@kasoftware.cn 联系我们。点击下方蓝色按钮,即可免费试用 EDI 软件。
标签: , , , ,
文章分类 EDI视频教程, 产品介绍, 帮助文档, 知识库