-2

我正在尝试学习一些用于从 EDi 837/835 文件中提取数据的 XLST。下面将从循环 2100 中指定的字段放入 cvs 格式,但不是循环 2110 中的字段。它下面的样式表将返回循环 2110 中的字段,而不是 2100。我如何组合循环以返回来自循环的字段2100 和 2110 在 1 个样式表中?我尝试了几个选项,但未能以 csv 格式返回所有字段。有任何想法吗?任何帮助是极大的赞赏。835 测试文件 ID 在底部。

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl"
>
<xsl:output method="text" indent="yes"/>

<xsl:template match="Interchange">
<xsl:apply-templates select="FunctionGroup/Transaction/Loop[@LoopId='2000']/Loop 
  [@LoopId='2100']"/>
 </xsl:template>


 <xsl:template match="Loop[@LoopId='2100'] "> 
<xsl:variable name="trans" select="../../."/>
<xsl:variable name="payer" select="../../Loop[@LoopId='1000A']"/>
<xsl:variable name="payee" select="../../Loop[@LoopId='1000B']"/>
<xsl:variable name="payment" select="."/>
 <xsl:variable name="cas" select="../../Loop[@LoopId='2110']"/>
 <xsl:variable name="caxx" select="."/>

<xsl:value-of select="$trans/BPR/BPR16"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$caxx/N1/N102"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payee/N1/N102"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payee/N1/N104"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payment/CLP/CLP01"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payment/CLP/CLP02"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payment/CLP/CLP03"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payment/NM1[NM101='QC']/NM103"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payment/NM1[NM101='QC']/NM104"/>
<xsl:value-of select="','"/>





 <xsl:value-of select="$cas/DTM[DTM01='472']/DTM02"/>
<xsl:value-of select="','"/>
 <xsl:value-of select="$payment/CAS[CAS01='CO']/CAS01"/>
 <xsl:value-of select="','"/>
  <xsl:value-of select="$payment/CAS[CAS01='CO']/CAS02"/>
 <xsl:value-of select="','"/>
      <xsl:value-of select="$payment/CAS[CAS01='CR']/CAS01"/>
 <xsl:value-of select="','"/>
 <xsl:value-of select="$payment/CAS[CAS01='CR']/CAS02"/>
 <xsl:value-of select="','"/>
      <xsl:value-of select="$payment/CAS[CAS01='OA']/CAS01"/>
 <xsl:value-of select="','"/>
 <xsl:value-of select="$payment/CAS[CAS01='OA']/CAS02"/>
 <xsl:value-of select="','"/>
         <xsl:value-of select="$payment/CAS[CAS01='PI']/CAS01"/>
 <xsl:value-of select="','"/>
  <xsl:value-of select="$payment/CAS[CAS01='PI']/CAS02"/>
 <xsl:value-of select="','"/>
<xsl:value-of select="$payment/CAS[CAS01='PR']/CAS01"/>
 <xsl:value-of select="','"/>
 <xsl:value-of select="$payment/CAS[CAS01='PR']/CAS02"/>
 <xsl:value-of select="','"/>
         <xsl:value-of select="$payment/REF[REF01='6R']/REF02"/>
 <xsl:value-of select="','"/>


    <xsl:value-of select="$cas/CAS[CAS01='PR']/CAS02"/>
 <xsl:value-of select="','"/>
 <xsl:text>&#x0A;</xsl:text>  
  </xsl:template>
 </xsl:stylesheet>

----------------------------------

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl"
>
 <xsl:output method="text" indent="yes"/>

<xsl:template match="Interchange">
<xsl:apply-templates select="FunctionGroup/Transaction/Loop[@LoopId='2000']/Loop  
  [@LoopId='2100']/Loop[@LoopId='2110']"/>
 </xsl:template>


<xsl:template match="Loop[@LoopId='2110'] "> 
<xsl:variable name="trans" select="../../."/>
<xsl:variable name="payer" select="../../Loop[@LoopId='1000A']"/>
<xsl:variable name="payee" select="../../Loop[@LoopId='1000B']"/>
<xsl:variable name="payment" select="."/>
 <xsl:variable name="cas" select="../../Loop[@LoopId='2110']"/>
 <xsl:variable name="caxx" select="."/>

<xsl:value-of select="$trans/BPR/BPR16"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$caxx/N1/N102"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payee/N1/N102"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payee/N1/N104"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payment/CLP/CLP01"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payment/CLP/CLP02"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payment/CLP/CLP03"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payment/NM1[NM101='QC']/NM103"/>
<xsl:value-of select="','"/>
<xsl:value-of select="$payment/NM1[NM101='QC']/NM104"/>
<xsl:value-of select="','"/>

 <xsl:value-of select="$cas/DTM[DTM01='472']/DTM02"/>
<xsl:value-of select="','"/>
 <xsl:value-of select="$payment/CAS[CAS01='CO']/CAS01"/>
 <xsl:value-of select="','"/>
  <xsl:value-of select="$payment/CAS[CAS01='CO']/CAS02"/>
 <xsl:value-of select="','"/>
      <xsl:value-of select="$payment/CAS[CAS01='CR']/CAS01"/>
 <xsl:value-of select="','"/>
 <xsl:value-of select="$payment/CAS[CAS01='CR']/CAS02"/>
 <xsl:value-of select="','"/>
      <xsl:value-of select="$payment/CAS[CAS01='OA']/CAS01"/>
 <xsl:value-of select="','"/>
 <xsl:value-of select="$payment/CAS[CAS01='OA']/CAS02"/>
 <xsl:value-of select="','"/>
         <xsl:value-of select="$payment/CAS[CAS01='PI']/CAS01"/>
 <xsl:value-of select="','"/>
  <xsl:value-of select="$payment/CAS[CAS01='PI']/CAS02"/>
 <xsl:value-of select="','"/>
<xsl:value-of select="$payment/CAS[CAS01='PR']/CAS01"/>
 <xsl:value-of select="','"/>
 <xsl:value-of select="$payment/CAS[CAS01='PR']/CAS02"/>
 <xsl:value-of select="','"/>
         <xsl:value-of select="$payment/REF[REF01='6R']/REF02"/>
 <xsl:value-of select=",'"/>


    <xsl:value-of select="$cas/CAS[CAS01='PR']/CAS02"/>
 <xsl:value-of select="','"/>
 <xsl:text>&#x0A;</xsl:text>
 </xsl:template>
 </xsl:stylesheet>

---------835 文件

ISA*00*          *00*          *ZZ*ASHTB          *ZZ*01017                 
*040315*1005*U*00401*004075123*0*P*:~

GS*HP*ASHTB*01017*20040315*1005*1*X*004010X091A1~
ST*835*07504123~
  BPR*H*5.75*C*NON************20040315~
  TRN*1*A04B001017.07504*1346000128~
  DTM*405*20040308~
  N1*PR*ASHTABULA COUNTY ADAMH BD~
    N3*4817 STATE ROAD SUITE 203~
    N4*ASHTABULA*OH*44004~
  N1*PE*LAKE AREA RECOVERY CENTER *FI*346608640~
    N3*2801 C. COURT~
    N4*ASHTABULA*OH*44004~
    REF*PQ*1017~
  LX*1~
    CLP*444444*1*56.70*56.52*0*MC*0000000655555555*53~
      NM1*QC*1*FUDD*ELMER*S***MI*1333333~
      NM1*82*2*WECOVERWY SVCS*****FI*346608640~
      REF*F8*A76B04054~
      SVC*HC:H0005:HF:H9*56.70*56.52**6~
        DTM*472*20040205~
        CAS*CO*42*0.18*0~
        REF*6R*444444~
    CLP*999999*4*25.95*0*25.95*13*0000000555555555*11~
      NM1*QC*1*SAM*YOSEMITE*A***MI*3333333~
      NM1*82*2*ACME AGENCY*****FI*310626223~
      REF*F8*H57B10401~
      SVC*ZZ:M2200:HE*25.95*0**1~
        DTM*472*20021224~
        CAS*CR*18*25.95*0~
        CAS*CO*42*0*0~
        REF*6R*999999~
    CLP*888888*4*162.13*0*162.13*MC*0000000456789123*11~
      NM1*QC*1*SQUAREPANTS*BOB* ***MI*2222222~
      NM1*82*2*BIKINI AGENCY*****FI*310626223~
      REF*F8*H57B10401~
      SVC*ZZ:M151000:F0*162.13*0**1.9~
        DTM*472*20020920~
        CAS*CO*29*162.13*0*42*0*0~
        REF*6R*888888~
    CLP*111111*2*56.52*18.88*0*13*0000000644444444*53~
      NM1*QC*1*LEGHORN*FOGHORN*P***MI*7777777~
      NM1*82*2*CHICKENHAWK SVCS*****FI*346608640~
      REF*F8*A76B04054~
      SVC*HC:H0005:HF:H9*56.52*18.88**6~
        DTM*472*20031209~
        CAS*CO*42*0*0~
        CAS*OA*23*37.64*0~
        REF*6R*111111~
    CLP*121212*4*56.52*0*0*13*0000000646464640*53~
      NM1*QC*1*EXPLORER*DORA****MI*1717171~
      NM1*82*2*SWIPER AGENCY*****FI*346608640~
      REF*F8*A76B04054~
      SVC*HC:H0005:HF:H9*56.52*0**6~
        DTM*472*20031202~
        CAS*CO*42*0*0~
        CAS*OA*23*57.6*0*23*-1.08*0~
        REF*6R*121212~
    CLP*333333*1*74.61*59.69*14.92*13*0000000688888888*55~
      NM1*QC*1*BEAR*YOGI* ***MI*2222222~
      NM1*82*2*JELLYSTONE SVCS*****FI*346608640~
      REF*F8*A76B04054~
      SVC*ZZ:A0230:HF*74.61*59.69**1~
        DTM*472*20040203~
        CAS*PR*2*14.92*0~
        CAS*CO*42*0*0~
        REF*6R*333333~
    CLP*777777*25*136.9*0*0*13*0000000622222222*53~
      NM1*QC*1*BIRD*TWEETY*M***MI*4444444~
      NM1*82*2*GRANNY AGENCY*****FI*340716747~
      REF*F8*A76B03293~
      SVC*HC:H0015:HF:99:H9*136.9*0**1~
        DTM*472*20030911~
        CAS*PI*104*136.72*0~
        CAS*CO*42*0.18*0~
        REF*6R*777777~
    CLP*123456*22*-42.58*-42.58*0*13*0000000657575757*11~
      NM1*QC*1*SIMPSON*HOMER* ***MI*8787888~
      NM1*82*2*DOH GROUP*****FI*310626223~
      REF*F8*A57B04033~
      SVC*HC:H0036:GT:UK*-42.58*-42.58**-2~
        DTM*472*20040102~
        CAS*CR*141*0*0*42*0*0*22*0*0~
        CAS*OA*141*0*0~
        REF*6R*123456~
    CLP*090909*22*-86.76*-86.76*0*MC*0000000648484848*53~
      NM1*QC*1*DUCK*DAFFY*W***MI*1245849~
      NM1*82*2*ABTHSOLUTE HELP*****FI*346608640~
      REF*F8*A76B04054~
      SVC*HC:H0004:HF:H9*-86.76*-86.76**-4~
        DTM*150*20040210~
        DTM*151*20040211~
        CAS*CR*22*0*0*42*0*0~
        CAS*OA*22*0*0~
        REF*6R*090909~
        AMT*AU*86.76~
        QTY*NE*53~
        LQ*HE*MA92~
  PLB*123456*19960930*CV:9876514*-1.27~
SE*97*07504123~
  GE*1*1~
IEA*1*004075123~
4

1 回答 1

0

查看您的两个样式表,唯一的区别在于xsl:apply-templates

<xsl:apply-templates select="FunctionGroup/Transaction/Loop[@LoopId='2000']/Loop 
                             [@LoopId='2100']"/>

和各自的模板匹配

<xsl:template match="Loop[@LoopId='2100'] ">

在这两种情况下,只有“2100”和“2110”不同。

要允许第一个 XSLT 管理“2100”和“2110”记录,请将现有的单个xsl:apply-templates替换为:

<xsl:apply-templates select="FunctionGroup/Transaction/Loop[@LoopId='2000']/Loop[@LoopId='2100']"/>
<xsl:apply-templates select="FunctionGroup/Transaction/Loop[@LoopId='2000']/Loop[@LoopId='2110']"/>

然后,将模板匹配更改为此,以共享模板

<xsl:template match="Loop[@LoopId='2100' or @LoopId='2110'] ">

试试这个(删节的)XSLT,它将您的两个 XSLT 样式表合二为一

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl">
<xsl:output method="text" indent="yes"/>

<xsl:template match="Interchange">
    <xsl:apply-templates select="FunctionGroup/Transaction/Loop[@LoopId='2000']/Loop[@LoopId='2100']"/>
    <xsl:apply-templates select="FunctionGroup/Transaction/Loop[@LoopId='2000']/Loop[@LoopId='2110']"/>
</xsl:template>

<xsl:template match="Loop[@LoopId='2100' or @LoopId='2110'] "> 
    <xsl:variable name="trans" select="../../."/>
    <xsl:variable name="caxx" select="."/>
    <xsl:value-of select="$trans/BPR/BPR16"/>
    <xsl:value-of select="','"/>
    <xsl:value-of select="$caxx/N1/N102"/>
    <xsl:text>&#x0A;</xsl:text>  
</xsl:template>
</xsl:stylesheet>
于 2014-06-23T08:26:31.460 回答