【问题标题】:Skip Header when converting BizTalk CSV to XML (After Generating Schema)将 BizTalk CSV 转换为 XML 时跳过标题(生成架构后)
【发布时间】:2015-06-18 20:52:46
【问题描述】:

我使用平面文件向导生成了我的架构,一切正常,除了我不希望 XML 中的标题。

似乎我应该能够更改架构中的一个属性并使其工作,但我一直在寻找并且找不到正确的属性(它是在架构、根元素还是重复组?)寻找类似“CSVContainsHeader”真/假的东西。

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

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

【问题讨论】:

  • “inventory_items”是你的标题吗?如果你在同一个模式中定义你的标题/正文,我认为你不能“忽略”标题,因为它会使消息无效。
  • 架构中没有标头。

标签: xml csv xsd schema biztalk


【解决方案1】:

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

最简单的方法是将架构中的记录或元素设置为“标题”元素,并在映射中忽略它。这可能是最直接的方法,即使其中有一个您不使用的记录/字段元素/属性很烦人。

您还可以创建单独的标头架构,然后在平面文件反汇编器上将“保留标头”属性设置为 false。这实际上只是一种更复杂的方式来执行与上述相同的操作,但是您使用的架构在映射时不会显示标头数据。

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

【讨论】:

  • 谢谢,所以如果我什至没有地图,是#1 出来的,还是我必须创建一个虚拟地图?整个项目只是将 SQL 提取 CSV 转换为 XML。 SQL 仅为此目的而构建,因此所有内容都完全匹配(不需要映射)。我记得现在使用方法 #2,但更多用于输出 CSV。
  • 添加了地图。做 BizTalk 10 年了,但是 CSV 从一个客户到另一个客户来来去去。希望 BizTalk 有一个自动删除标题功能。所以我添加了一个标题记录(子分隔符设置为 "," ,有 5 个虚拟列,每个实际列一个,最小/最大发生 = 1)。然后我创建了新地图,似乎比创建第二个模式要容易一些。工作正常。谢谢
  • 很高兴听到。如果您不需要地图,那么您就不需要地图 - 您可以将标题留在虚拟元素中,或者您可以使用两种模式方法并忽略输出中的标题模式。
猜你喜欢
  • 2023-03-17
  • 2023-03-20
  • 2023-04-09
  • 1970-01-01
  • 2019-10-15
  • 1970-01-01
  • 2016-08-26
  • 2013-06-20
  • 2013-10-04
相关资源
最近更新 更多