[英]XSLT 1.0 - Use delimiter to split fields inside for-each loop
我有一個需要轉換的XML文件。 我能夠構建在沒有分隔符的第一種情況下可以工作的XSLT文件,但是現在在第二種情況下,有一個需要分隔成兩個字段的定界符+字段。
這是第二種情況下的源XML。 百分號+位於“組/組/詳細信息/部分/字段/'FieldName='{STATION.Comments}'/值”字段中:
<?xml version="1.0" encoding="UTF-8"?>
<CrystalReport xmlns="urn:crystal-reports:schemas:report-detail" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:crystal-reports:schemas:report-detail http://www.businessobjects.com/products/xml/CR2008Schema.xsd">
<Group Level="1">
<GroupHeader>
<Section SectionNumber="0">
<Field FieldName="{STATION.Item}" Name="Field5">
<FormattedValue>TR-BP169-10</FormattedValue>
<Value>TR-BP169-10</Value>
</Field>
<Text Name="Text30">
<TextValue>Item</TextValue>
</Text>
<Field FieldName="{INVENTRY.Description2}" Name="Field7">
<FormattedValue>TRW Automotive</FormattedValue>
<Value>TRW Automotive</Value>
</Field>
</Section>
</GroupHeader>
<Group Level="2">
<Details Level="3">
<Section SectionNumber="0">
<Field FieldName="{STATION.Quantity}" Name="Field9">
<FormattedValue>11</FormattedValue>
<Value>11</Value>
</Field>
<Field FieldName="{STATION.Comments}" Name="Field23">
<FormattedValue>SWBP169-10</FormattedValue>
<Value>SWBP169-10+EA</Value>
</Field>
</Section>
</Details>
</Group>
<GroupFooter>
<Section SectionNumber="0">
<Field FieldName="Sum ({STATION.Quantity}, {STATION.Item})" Name="Field24">
<FormattedValue>47</FormattedValue>
<Value>47.00</Value>
</Field>
</Section>
</GroupFooter>
</Group>
<Group Level="1">
<GroupHeader>
<Section SectionNumber="0">
<Field FieldName="{STATION.Item}" Name="Field5">
<FormattedValue>TR-Y19CFC</FormattedValue>
<Value>TR-Y19CFC</Value>
</Field>
<Text Name="Text30">
<TextValue>Item</TextValue>
</Text>
<Field FieldName="{INVENTRY.Description2}" Name="Field7">
<FormattedValue>TRW Automotive</FormattedValue>
<Value>TRW Automotive</Value>
</Field>
</Section>
</GroupHeader>
<Group Level="2">
<Details Level="3">
<Section SectionNumber="0">
<Field FieldName="{STATION.Quantity}" Name="Field9">
<FormattedValue>9</FormattedValue>
<Value>9</Value>
</Field>
<Field FieldName="{STATION.Comments}" Name="Field23">
<FormattedValue>Y19CFC</FormattedValue>
<Value>Y19CFC+EA</Value>
</Field>
</Section>
</Details>
</Group>
<GroupFooter>
<Section SectionNumber="0">
<Field FieldName="Sum ({STATION.Quantity}, {STATION.Item})" Name="Field24">
<FormattedValue>18</FormattedValue>
<Value>18.00</Value>
</Field>
</Section>
</GroupFooter>
</Group>
</CrystalReport>
這是我未添加定界符的第一種情況下的XSLT 1.0文件:
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:cr="urn:crystal-reports:schemas:report-detail"
exclude-result-prefixes="cr msxsl cs"
xmlns:msxsl="urn:schemas-microsoft-com:xslt"
xmlns:cs="urn:cs">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<msxsl:script language="C#" implements-prefix="cs">
<![CDATA[
public string datenow()
{
return(DateTime.Now.ToString("yyyy'-'MM'-'dd"));
}
]]>
</msxsl:script>
<xsl:template match="/cr:CrystalReport">
<Envelope xmlns="http://schemas.microsoft.com/dynamics/2011/01/documents/Message">
<Header>
<Company>tgs</Company>
<Action>http://schemas.microsoft.com/dynamics/2008/01/services/SalesOrderService/create</Action>
</Header>
<Body>
<MessageParts>
<SalesOrder xmlns="http://schemas.microsoft.com/dynamics/2008/01/documents/SalesOrder">
<SalesTable class="entity">
<CustAccount>
<xsl:value-of select="cr:Group/cr:GroupHeader/cr:Section/cr:Field[@FieldName='{INVENTRY.Description2}']/cr:Value"/>
</CustAccount>
<PurchOrderFormNum>PO</PurchOrderFormNum>
<ReceiptDateRequested><xsl:value-of select="cs:datenow()"/></ReceiptDateRequested>
<!-- sale lines -->
<xsl:for-each select="cr:Group">
<SalesLine class="entity">
<ItemId>
<xsl:value-of select="cr:Group/cr:Details/cr:Section/cr:Field[@FieldName='{STATION.Comments}']/cr:Value"/>
</ItemId>
<SalesQty>
<xsl:value-of select="cr:GroupFooter/cr:Section/cr:Field[@FieldName='Sum ({STATION.Quantity}, {STATION.Item})']/cr:FormattedValue"/>
</SalesQty>
<SalesUnit>EA</SalesUnit>
</SalesLine>
</xsl:for-each>
</SalesTable>
</SalesOrder>
</MessageParts>
</Body>
</Envelope>
</xsl:template>
</xsl:stylesheet>
這是期望的輸出,使用分隔符分隔字段。 使用定界符來創建兩個字段,其中一個用於itemid,第二個用於SalesUNIT:
<?xml version="1.0" encoding="UTF-8"?>
<Envelope xmlns="http://schemas.microsoft.com/dynamics/2011/01/documents/Message">
<Header>
<Company>tgs</Company>
<Action>http://schemas.microsoft.com/dynamics/2008/01/services/SalesOrderService/create</Action>
</Header>
<Body>
<MessageParts>
<SalesOrder xmlns="http://schemas.microsoft.com/dynamics/2008/01/documents/SalesOrder">
<SalesTable class="entity">
<CustAccount>TRW Automotive</CustAccount>
<PurchOrderFormNum>PO</PurchOrderFormNum>
<ReceiptDateRequested>2019-08-01</ReceiptDateRequested>
<SalesLine class="entity">
<ItemId>SWBP169-10</ItemId>
<SalesQty>47</SalesQty>
<SalesUnit>EA</SalesUnit>
</SalesLine>
<SalesLine class="entity">
<ItemId>Y19CFC</ItemId>
<SalesQty>18</SalesQty>
<SalesUnit>EA</SalesUnit>
</SalesLine>
</SalesTable>
</SalesOrder>
</MessageParts>
</Body>
</Envelope>
提前致謝。
如果源將始終包含兩個用+
分隔的值,則可以使用以下方法提取第一個值:
substring-before(Value, '+')
第二個是:
substring-after(Value, '+')
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.