我是骡子的新手,所以请耐心等待。我收到以下CSV文件:
Company1,2,123 Street,Winchester,UK
"000010","CHRISTINE","I","HAAS","A00","3978","1995-01-01","PRES",18,"F","1963-08-24",152750.00
"000020","MICHAEL","L","THOMPSON","B01","3476","2003-10-10","MANAGER",18,"M","1978-02-02",94250.00
第一行标题包含公司信息加上CSV文件中的记录数(员工数)(标题中的第二个参数)。
现在我需要将其转换为以下XML:
<?xml version="1.0" encoding="UTF-8"?>
<tns:employeedata xmlns:tns="http://coxb.test.legstar.com/payrollemployee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://coxb.test.legstar.com/payrollemployee PayrollEmployee.xsd ">
<tns:employeecount>2</tns:employeecount>
<tns:employeelist>
<tns:employees>
<tns:employeenumber>000010</tns:employeenumber>
<tns:firstname>CHRISTINE</tns:firstname>
<tns:middleinitial>I</tns:middleinitial>
<tns:surname>HAAS</tns:surname>
<tns:department>A00</tns:department>
</tns:employees>
<tns:employees>
<tns:employeenumber>000020</tns:employeenumber>
<tns:firstname>MICHAEL</tns:firstname>
<tns:middleinitial>L</tns:middleinitial>
<tns:surname>THOMPSON</tns:surname>
<tns:department>B01</tns:department>
</tns:employees>
</tns:employeelist>
</tns:employeedata>
我可以在没有第一行(标题)的情况下轻松转换此文件。我的问题是如何处理标题并提取/转换“employeecount”。
非常感谢任何帮助。
答案 0 :(得分:0)
最简单的方法是使用DataMapper。将输入设置为CSV(使用示例CSV)并将输出设置为XML(使用XSD或示例XML)。
进入映射视图后,单击您的employeecount字段。您将看到一个可以输入表达式的区域。有一个未记录的参数$in.0.__id
,您可以使用它包含记录计数。请注意,这仅适用于CSV文件。
关于如何跳过第一行,DataMapper默认执行此操作。