将 BizTalk CSV 转换为 XML 时跳过 Header(生成架构后)

Skip Header when converting BizTalk CSV to XML (After Generating Schema)

我使用平面文件向导生成了我的模式,一切正常,除了我不想在我的 XML 中使用 header。

似乎我应该能够更改架构中的一个 属性 并使其正常工作,但我一直在寻找但找不到正确的 属性(它是否在架构、根元素或重复组?)寻找类似 "CSVContainsHeader" true/false 的内容。

我的架构的第一部分如下所示:

- <xs:schema xmlns:b="http://schemas.microsoft.com/BizTalk/2003" xmlns:xs="http://www.w3.org/2001/XMLSchema">
- <xs:annotation>
- <xs:appinfo>
  <schemaEditorExtension:schemaInfo namespaceAlias="b" extensionClass="Microsoft.BizTalk.FlatFileExtension.FlatFileExtension" standardName="Flat File" xmlns:schemaEditorExtension="http://schemas.microsoft.com/BizTalk/2003/SchemaEditorExtensions" /> 
  <b:schemaInfo standard="Flat File" codepage="65001" default_pad_char="" pad_char_type="char" count_positions_by_byte="false" parser_optimization="speed" lookahead_depth="3" suppress_empty_nodes="false" generate_empty_nodes="true" allow_early_termination="false" early_terminate_optional_fields="false" allow_message_breakup_of_infix_root="false" compile_parse_tables="false" root_reference="inventory_items" /> 
  </xs:appinfo>
  </xs:annotation>
- <xs:element name="inventory_items">
- <xs:annotation>
- <xs:appinfo>
  <b:recordInfo structure="delimited" child_delimiter_type="hex" child_delimiter="0xD 0xA" child_order="postfix" sequence_number="1" preserve_delimiter_for_empty_data="true" suppress_trailing_delimiters="false" /> 
  </xs:appinfo>
  </xs:annotation>
- <xs:complexType>
- <xs:sequence>
- <xs:annotation>
- <xs:appinfo>
  <groupInfo sequence_number="0" xmlns="http://schemas.microsoft.com/BizTalk/2003" /> 
  </xs:appinfo>
  </xs:annotation>
- <xs:element maxOccurs="unbounded" name="item">
- <xs:annotation>
- <xs:appinfo>
  <b:recordInfo structure="delimited" child_delimiter_type="char" child_delimiter="," child_order="infix" sequence_number="1" preserve_delimiter_for_empty_data="true" suppress_trailing_delimiters="false" /> 
  </xs:appinfo>
  </xs:annotation>

无法让平面文件反汇编程序完全忽略 header 内容,但有几种方法可以实现您的目标。

最简单的方法是将架构中的记录或元素设为 'Header' 元素,并在映射中忽略它。这可能是最直接的方法,即使其中有一个您不使用的 record/field element/attribute 很烦人。

您还可以创建一个单独的 header 架构,然后在平面文件反汇编程序上将 "Preserve Header" 属性 设置为 false。这实际上只是一种与上述相同的更复杂的方式,但您使用的架构在映射时不会显示 header 数据。

最后,您可以为没有 header 的文档实例创建模式,然后编写自定义管道组件以从解码中的传入消息中删除 header 行阶段。虽然这在技术上可行,但我不能说我会推荐引入这个额外的依赖项来实现它。