我必须解析一个只包含订单项数据的CSV平面文件,没有可识别的标题记录,有点像这样:
930001,14-02-2013,100.00,1,Line 1,2,10.00,20.00
930001,14-02-2013,100.00,2,Line 2,2,20.00,40.00
930001,14-02-2013,100.00,3,Line 3,1,40.00,40.00
930002,13-02-2013,200.00,1,Line 1,10,10.00,100.00
930002,13-02-2013,200.00,2,Line 2,5,20.00,100.00
930003,14-02-2013,100.00,1,Line 1,3,20.00,60.00
930003,14-02-2013,100.00,2,Line 2,2,20.00,40.00
字段在哪里,按顺序:
Order No,Order Date,Order Amt,Line No,Line Desc,Line Qty,Unit Price,Line Price
我想使用BizTalk平面文件接收管道将其转换为分层架构,在第一个字段上分组,订单号:
Order_Batch
+ Order
+ OrderLine
有没有办法通过平面文件接收执行分组操作,因此,在上面的例子中,前3行(订单号= 930001)
<OrderBatch>
<Order>
<OrderLine>
<OrderNo>930001</OrderNo>
<other_fields />
<LineNo>1</LineNo>
<other_fields_etc />
</OrderLine>
<OrderLine>
<OrderNo>930001</OrderNo>
<other_fields />
<LineNo>2</LineNo>
<other_fields_etc />
</OrderLine>
<OrderLine>
<OrderNo>930001</OrderNo>
<other_fields />
<LineNo>2</LineNo>
<other_fields_etc />
</OrderLine>
</Order>
<Order> ... Details of Order 930002 ... </Order>
<Order> ... Details of Order 930003 ... </Order>
</OrderBatch>
我目前看到的唯一选项是将整个文件作为一组OrderLine记录接受,不进行批处理,然后使用另一个Orchestration中的Gather模式执行批处理。我宁愿保持严肃认真。
答案 0 :(得分:0)
使用地图从平面转换为层次结构:
我相信您可以在地图中使用xsl,您可以执行grouping