我正在尝试学习一些用于从 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>
</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>
</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~