Разбор ввода с помощью DFDL в одной строке - PullRequest
0 голосов
/ 25 июня 2019

У меня есть набор данных сообщения MT940

C 180731 LKR 50000,00

Я хочу, чтобы это отображалось как с XSD.Может кто-нибудь помочь мне с XSD.

C180731LKR50000,00

1 Ответ

0 голосов
/ 25 июня 2019

Следующее проверено с Apache Daffodil 2.3.0 :

<xs:schema
  xmlns:xs="http://www.w3.org/2001/XMLSchema"
  xmlns:dfdl="http://www.ogf.org/dfdl/dfdl-1.0/">

  <xs:include schemaLocation="org/apache/daffodil/xsd/DFDLGeneralFormat.dfdl.xsd" />

  <xs:annotation>
    <xs:appinfo source="http://www.ogf.org/dfdl/">
      <dfdl:format ref="GeneralFormat"
        representation="text" />
    </xs:appinfo>
  </xs:annotation>

  <xs:element name="MT940">
    <xs:complexType>
      <xs:sequence>
        <xs:element name="CreditDebitIndicator" type="xs:string"
          dfdl:lengthKind="explicit" dfdl:length="1" />
        <xs:element name="Date" type="xs:date"
          dfdl:lengthKind="explicit" dfdl:length="6"
          dfdl:calendarPatternKind="explicit" dfdl:calendarPattern="yyMMdd" />
        <xs:element name="Currency" type="xs:string"
          dfdl:lengthKind="explicit" dfdl:length="3" />
        <xs:element name="Amount" type="xs:decimal"
          dfdl:lengthKind="delimited" dfdl:textNumberCheckPolicy="strict"
          dfdl:textNumberPattern="#0.00"
          dfdl:textStandardDecimalSeparator=","
          dfdl:textStandardGroupingSeparator="." />
      </xs:sequence>
    </xs:complexType>
  </xs:element>

</xs:schema>

При анализе данных в качестве примера получается следующий XML:

<MT940>
  <CreditDebitIndicator>C</CreditDebitIndicator>
  <Date>2018-07-31</Date>
  <Currency>LKR</Currency>
  <Amount>50000</Amount>
</MT940>

Обратите внимание, чтосумма не имеет десятичных дробей, потому что дробная часть была 00, и Daffodil выводит канонизированные числа.Если бы вместо этого было что-то вроде «50000,99», оно выглядело бы как <Amount>50000.99</Amount>.

...