Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

  1. #1
    Candidat au Club
    Tentative de conversion de valeurs sur plusieurs balises identiques
    Bonjour à tous,

    Etant complètement néophyte dans la création d'XSLT, j'ai énormément de mal à réaliser ce que je souhaite... j'en appelle donc à votre aide .

    Voici le contexte :

    Travaillant actuellement sur un WMS (logiciel de gestion d'entrepôt), celui ci envoie plusieurs messages à un ERP pour confirmer des réceptions, des mouvements de stocks,etc. On appelle ces messages des PIX, ils ont tous la même structure et sont envoyés sous format XML. Un même fichier XML peut comporter plusieurs PIX.
    Notre WMS travaillant en centimètres et notre ERP en mètres, je dois appliquer une conversion directement sur mon XML de sortie sur certaines balises particulières avant d'envoyer le message à mon ERP. D'où l'utilisation d'un XSLT.

    En partant , d'un fichier comportant uniquement un PIX comme celui ci :

    Code :Sélectionner tout -Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    <?xml version="1.0" encoding="UTF-8"?>
    <tXML>
    	<Header>
    		<Source>MANH_wms</Source>
    		<Message_Type>PIX</Message_Type>
    	</Header>
    	<Message>
    		<PIX>
    			<TransactionType>606</TransactionType>
    			<TransactionCode>03</TransactionCode>
    			<TransactionNumber>14818</TransactionNumber>
    			<SequenceNumber>1</SequenceNumber>
    			<UserID>WMADMIN</UserID> 
    			<ItemDefinition>
    				<Style>2020</Style>
    				<StyleSuffix>TISS1</StyleSuffix>
    				<SizeDesc>01</SizeDesc>
    			</ItemDefinition>
    			<SubItemFields>
    				<InventoryType>F</InventoryType>
    				<BatchNumber></BatchNumber>
    			</SubItemFields>
    			<PIXFields>
    				<DateCreated>04/16/20 18:50:49</DateCreated>
    				<InvAdjustmentQty>200</InvAdjustmentQty>
    				<UnitOfMeasure>M</UnitOfMeasure>
    				<InvAdjustmentType>A</InvAdjustmentType>
    				<Warehouse>FRM</Warehouse>
    				<TransReasonCode></TransReasonCode>
    				<ReceiptsVariance></ReceiptsVariance>
    				<UnitsShipped>0</UnitsShipped>
    				<UnitsReceived>200</UnitsReceived>
    				<ReferenceCode1>12</ReferenceCode1>
    				<Reference1>POW105001</Reference1>
    				<ReferenceCode2>C02</ReferenceCode2>
    				<Reference2>BL00000123</Reference2>
    				<ReferenceCode3>C03</ReferenceCode3>
    				<Reference3>2020-04-07 03:46:00.0</Reference3>
    				<ReferenceCode4>37</ReferenceCode4>
    				<Reference4>5001285</Reference4>
    				<ReferenceCode5>43</ReferenceCode5>
    				<Reference5>PW105-TISS1-01-3</Reference5>
    				<ReferenceCode6>08</ReferenceCode6>
    				<Reference6>000000110</Reference6>
    				<ReferenceCode7>C07</ReferenceCode7>
    				<Reference7></Reference7>
    				<ReferenceCode8>25</ReferenceCode8>
    				<Reference8>QH</Reference8>
    				<ReferenceCode9></ReferenceCode9>
    				<Reference9></Reference9>
    				<ReferenceCode10></ReferenceCode10>
    				<Reference10></Reference10>
    				<ActionCode></ActionCode>
    			</PIXFields>
    		</PIX>
    	</Message>
    </tXML>


    Je souhaite modifier les balises <InvAdjustmentQty>, <UnitsShipped> et , <UnitsReceived> à condition que la valeur de <UnitOfMeasure> soit en M ou M2 . Sinon je ne réalise aucune opération et renvoie la valeur initiale.

    Voici donc ce que j'ai réalisé :

    Code :Sélectionner tout -Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    <?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet version="1.0" xmlns<img src="images/smilies/icon_mad.gif" border="0" alt="" title=":x" class="inlineimg" />sl="http://www.w3.org/1999/XSL/Transform">
    	<xsl:output omit-xml-declaration="yes" indent="yes"/>    
     
    	<xsl:template match="node()|@*">
    		<xsl:copy>
    			<xsl:apply-templates select="node()|@*"/>
    		</xsl:copy>
    	</xsl:template>
     
    	<!--  Template Conversion Valeur-->
    	<xsl:variable name= "var1"  select = "0.01"/>
    	<xsl:variable name= "var2"  select = "0.0001"/>
    	<xsl:template match="*/UnitsReceived">
    		<xsl:choose>
    			<xsl:when test="/tXML/Message/PIX/PIXFields/UnitOfMeasure='M'"> 
    				<UnitsReceived>
    				<xsl:value-of select="/tXML/Message/PIX/PIXFields/UnitsReceived * $var1"/>
    				</UnitsReceived>
    			</xsl:when>
    			<xsl:when test="/tXML/Message/PIX/PIXFields/UnitOfMeasure='M2'"> 
    				<UnitsReceived>
    				<xsl:value-of select="/tXML/Message/PIX/PIXFields/UnitsReceived * $var2"/>
    				</UnitsReceived>
    			</xsl:when>
    			<xsl:otherwise>
    			<UnitsReceived>
    					<xsl:value-of select="node()|@*"/>
    			</UnitsReceived>
    			</xsl:otherwise>	
    		</xsl:choose>
    	</xsl:template>
    	<xsl:template match="*/UnitsShipped">
    		<xsl:choose>
    			<xsl:when test="/tXML/Message/PIX/PIXFields/UnitOfMeasure='M'"> 
    			<UnitsShipped>
    				<xsl:value-of select="/tXML/Message/PIX/PIXFields/UnitsShipped * $var1"/>
    			</UnitsShipped>
    			</xsl:when>
    			<xsl:when test="/tXML/Message/PIX/PIXFields/UnitOfMeasure='M2'"> 
    				<UnitsShipped>
    				<xsl:value-of select="/tXML/Message/PIX/PIXFields/UnitsShipped * $var2"/>
    				</UnitsShipped>
    			</xsl:when>
    			<xsl:otherwise>
    			<UnitsShipped>
    					<xsl:value-of select="node()|@*"/>
    			</UnitsShipped>
    			</xsl:otherwise>	
    		</xsl:choose>
    	</xsl:template>
    	<xsl:template match="*/InvAdjustmentQty">	
    		<xsl:choose>
    			<xsl:when test="/tXML/Message/PIX/PIXFields/UnitOfMeasure='M'"> 
    			<InvAdjustmentQty>
    				<xsl:value-of select="/tXML/Message/PIX/PIXFields/InvAdjustmentQty * $var1"/>
    			</InvAdjustmentQty>
    			</xsl:when>
    			<xsl:when test="/tXML/Message/PIX/PIXFields/UnitOfMeasure='M2'"> 
    				<InvAdjustmentQty>
    				<xsl:value-of select="/tXML/Message/PIX/PIXFields/InvAdjustmentQty * $var2"/>
    				</InvAdjustmentQty>
    			</xsl:when>
    			<xsl:otherwise>
    			<InvAdjustmentQty>
    					<xsl:value-of select="node()|@*"/>
    			</InvAdjustmentQty>
    			</xsl:otherwise>	
    		</xsl:choose>
    	</xsl:template>
    </xsl:stylesheet>


    J'obtiens bien ce que je veux à savoir :

    Code :Sélectionner tout -Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    <tXML>
    	<Header>
    		<Source>MANH_wms</Source>
    		<Message_Type>PIX</Message_Type>
    	</Header>
    	<Message>
    		<PIX>
    			<TransactionType>606</TransactionType>
    			<TransactionCode>03</TransactionCode>
    			<TransactionNumber>14818</TransactionNumber>
    			<SequenceNumber>1</SequenceNumber>
    			<UserID>WMADMIN</UserID> 
    			<ItemDefinition>
    				<Style>2020</Style>
    				<StyleSuffix>TISS1</StyleSuffix>
    				<SizeDesc>01</SizeDesc>
    			</ItemDefinition>
    			<SubItemFields>
    				<InventoryType>F</InventoryType>
    				<BatchNumber/>
    			</SubItemFields>
    			<PIXFields>
    				<DateCreated>04/16/20 18:50:49</DateCreated>
    				<InvAdjustmentQty>20</InvAdjustmentQty>
    				<UnitOfMeasure>M</UnitOfMeasure>
    				<InvAdjustmentType>A</InvAdjustmentType>
    				<Warehouse>FRM</Warehouse>
    				<TransReasonCode/>
    				<ReceiptsVariance/>
    				<UnitsShipped>100</UnitsShipped>
    				<UnitsReceived>50</UnitsReceived>
    				<ReferenceCode1>12</ReferenceCode1>
    				<Reference1>POW105001</Reference1>
    				<ReferenceCode2>C02</ReferenceCode2>
    				<Reference2>BL00000123</Reference2>
    				<ReferenceCode3>C03</ReferenceCode3>
    				<Reference3>2020-04-07 03:46:00.0</Reference3>
    				<ReferenceCode4>37</ReferenceCode4>
    				<Reference4>5001285</Reference4>
    				<ReferenceCode5>43</ReferenceCode5>
    				<Reference5>PW105-TISS1-01-3</Reference5>
    				<ReferenceCode6>08</ReferenceCode6>
    				<Reference6>000000110</Reference6>
    				<ReferenceCode7>C07</ReferenceCode7>
    				<Reference7/>
    				<ReferenceCode8>25</ReferenceCode8>
    				<Reference8>QH</Reference8>
    				<ReferenceCode9/>
    				<Reference9/>
    				<ReferenceCode10/>
    				<Reference10/>
    				<ActionCode/>
    			</PIXFields>
    		</PIX>
    	</Message>
    </tXML>


    Jusque là c'est OK. Sauf que dans mon fichier XML, comme je l'ai mentionné plus haut, plusieurs PIX seront présents (un nombre de PIX aléatoire).
    Supposons maintenant que mon WMS envoie 3 PIX dans un même fichier. Les deux premiers en M éligibles à une conversion , le dernier en Unit non.

    Code :Sélectionner tout -Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    <?xml version="1.0" encoding="UTF-8"?>
    <tXML>
    	<Header>
    		<Source>MANH_wms</Source>
    		<Message_Type>PIX</Message_Type>
    	</Header>
    	<Message>
    		<PIX>
    			<TransactionType>300</TransactionType>
    			<TransactionCode>01</TransactionCode>
    			<TransactionNumber>14836</TransactionNumber>
    			<SequenceNumber>1</SequenceNumber>
    			<ItemDefinition>
    				<Style>2020</Style>
    				<StyleSuffix>CUIR1</StyleSuffix>
    				<SizeDesc>01</SizeDesc>
    			</ItemDefinition>
    			<SubItemFields>
    				<InventoryType>P</InventoryType>
    				<BatchNumber>A128348</BatchNumber>
    			</SubItemFields>
    			<PIXFields>
    				<DateCreated>04/16/20 19:44:22</DateCreated>
    				<InvAdjustmentQty>10000</InvAdjustmentQty>
    				<UnitOfMeasure>M</UnitOfMeasure>
    				<InvAdjustmentType>S</InvAdjustmentType>
    				<Warehouse>FRM</Warehouse>
    				<TransReasonCode></TransReasonCode>
    				<ReceiptsVariance></ReceiptsVariance>
    				<UnitsShipped>150</UnitsShipped>
    				<UnitsReceived>3000</UnitsReceived>
    				<ReferenceCode1>12</ReferenceCode1>
    				<Reference1>110350</Reference1>
    				<ReferenceCode2>C02</ReferenceCode2>
    				<Reference2>BL00001123</Reference2>
    				<ReferenceCode3>C03</ReferenceCode3>
    				<Reference3>2016-09-15 03:28:00.0</Reference3>
    				<ReferenceCode4>37</ReferenceCode4>
    				<Reference4></Reference4>
    				<ReferenceCode5>43</ReferenceCode5>
    				<Reference5></Reference5>
    				<ReferenceCode6>08</ReferenceCode6>
    				<Reference6>SASN20301</Reference6>
    				<ReferenceCode7>C07</ReferenceCode7>
    				<Reference7></Reference7>
    				<ReferenceCode8>25</ReferenceCode8>
    				<Reference8>PS</Reference8>
    				<ReferenceCode9></ReferenceCode9>
    				<Reference9></Reference9>
    				<ReferenceCode10></ReferenceCode10>
    				<Reference10></Reference10>
    				<ActionCode>19</ActionCode>
    			</PIXFields>
    		</PIX>
    				<PIX>
    			<TransactionType>300</TransactionType>
    			<TransactionCode>01</TransactionCode>
    			<TransactionNumber>14836</TransactionNumber>
    			<SequenceNumber>1</SequenceNumber>
    			<ItemDefinition>
    				<Style>2020</Style>
    				<StyleSuffix>CUIR1</StyleSuffix>
    				<SizeDesc>01</SizeDesc>
    			</ItemDefinition>
    			<SubItemFields>
    				<InventoryType>P</InventoryType>
    				<BatchNumber>A128348</BatchNumber>
    			</SubItemFields>
    			<PIXFields>
    				<DateCreated>04/16/20 19:44:22</DateCreated>
    				<InvAdjustmentQty>3000</InvAdjustmentQty>
    				<UnitOfMeasure>M</UnitOfMeasure>
    				<InvAdjustmentType>S</InvAdjustmentType>
    				<Warehouse>FRM</Warehouse>
    				<TransReasonCode></TransReasonCode>
    				<ReceiptsVariance></ReceiptsVariance>
    				<UnitsShipped>0</UnitsShipped>
    				<UnitsReceived>3000</UnitsReceived>
    				<ReferenceCode1>12</ReferenceCode1>
    				<Reference1>110350</Reference1>
    				<ReferenceCode2>C02</ReferenceCode2>
    				<Reference2>BL00001123</Reference2>
    				<ReferenceCode3>C03</ReferenceCode3>
    				<Reference3>2016-09-15 03:28:00.0</Reference3>
    				<ReferenceCode4>37</ReferenceCode4>
    				<Reference4></Reference4>
    				<ReferenceCode5>43</ReferenceCode5>
    				<Reference5></Reference5>
    				<ReferenceCode6>08</ReferenceCode6>
    				<Reference6>SASN20301</Reference6>
    				<ReferenceCode7>C07</ReferenceCode7>
    				<Reference7></Reference7>
    				<ReferenceCode8>25</ReferenceCode8>
    				<Reference8>PS</Reference8>
    				<ReferenceCode9></ReferenceCode9>
    				<Reference9></Reference9>
    				<ReferenceCode10></ReferenceCode10>
    				<Reference10></Reference10>
    				<ActionCode>19</ActionCode>
    			</PIXFields>
    		</PIX>
     
    				<PIX>
    			<TransactionType>300</TransactionType>
    			<TransactionCode>01</TransactionCode>
    			<TransactionNumber>14836</TransactionNumber>
    			<SequenceNumber>1</SequenceNumber>
    			<ItemDefinition>
    				<Style>2020</Style>
    				<StyleSuffix>CUIR1</StyleSuffix>
    				<SizeDesc>01</SizeDesc>
    			</ItemDefinition>
    			<SubItemFields>
    				<InventoryType>P</InventoryType>
    				<BatchNumber>A128348</BatchNumber>
    			</SubItemFields>
    			<PIXFields>
    				<DateCreated>04/16/20 19:44:22</DateCreated>
    				<InvAdjustmentQty>4000</InvAdjustmentQty>
    				<UnitOfMeasure>Unit</UnitOfMeasure>
    				<InvAdjustmentType>S</InvAdjustmentType>
    				<Warehouse>FRM</Warehouse>
    				<TransReasonCode></TransReasonCode>
    				<ReceiptsVariance></ReceiptsVariance>
    				<UnitsShipped>0</UnitsShipped>
    				<UnitsReceived>4000</UnitsReceived>
    				<ReferenceCode1>12</ReferenceCode1>
    				<Reference1>110350</Reference1>
    				<ReferenceCode2>C02</ReferenceCode2>
    				<Reference2>BL00001123</Reference2>
    				<ReferenceCode3>C03</ReferenceCode3>
    				<Reference3>2016-09-15 03:28:00.0</Reference3>
    				<ReferenceCode4>37</ReferenceCode4>
    				<Reference4></Reference4>
    				<ReferenceCode5>43</ReferenceCode5>
    				<Reference5></Reference5>
    				<ReferenceCode6>08</ReferenceCode6>
    				<Reference6>SASN20301</Reference6>
    				<ReferenceCode7>C07</ReferenceCode7>
    				<Reference7></Reference7>
    				<ReferenceCode8>25</ReferenceCode8>
    				<Reference8>PS</Reference8>
    				<ReferenceCode9></ReferenceCode9>
    				<Reference9></Reference9>
    				<ReferenceCode10></ReferenceCode10>
    				<Reference10></Reference10>
    				<ActionCode>19</ActionCode>
    			</PIXFields>
    		</PIX>
    	</Message>
    </tXML>


    Si je lance la transformation, j'obtiens ceci :

    Code :Sélectionner tout -Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    <tXML>
    	<Header>
    		<Source>MANH_wms</Source>
    		<Message_Type>PIX</Message_Type>
    	</Header>
    	<Message>
    		<PIX>
    			<TransactionType>300</TransactionType>
    			<TransactionCode>01</TransactionCode>
    			<TransactionNumber>14836</TransactionNumber>
    			<SequenceNumber>1</SequenceNumber>
    			<ItemDefinition>
    				<Style>2020</Style>
    				<StyleSuffix>CUIR1</StyleSuffix>
    				<SizeDesc>01</SizeDesc>
    			</ItemDefinition>
    			<SubItemFields>
    				<InventoryType>P</InventoryType>
    				<BatchNumber>A128348</BatchNumber>
    			</SubItemFields>
    			<PIXFields>
    				<DateCreated>04/16/20 19:44:22</DateCreated>
    				<InvAdjustmentQty>100</InvAdjustmentQty>
    				<UnitOfMeasure>M</UnitOfMeasure>
    				<InvAdjustmentType>S</InvAdjustmentType>
    				<Warehouse>FRM</Warehouse>
    				<TransReasonCode/>
    				<ReceiptsVariance/>
    				<UnitsShipped>1.5</UnitsShipped>
    				<UnitsReceived>30</UnitsReceived>
    				<ReferenceCode1>12</ReferenceCode1>
    				<Reference1>110350</Reference1>
    				<ReferenceCode2>C02</ReferenceCode2>
    				<Reference2>BL00001123</Reference2>
    				<ReferenceCode3>C03</ReferenceCode3>
    				<Reference3>2016-09-15 03:28:00.0</Reference3>
    				<ReferenceCode4>37</ReferenceCode4>
    				<Reference4/>
    				<ReferenceCode5>43</ReferenceCode5>
    				<Reference5/>
    				<ReferenceCode6>08</ReferenceCode6>
    				<Reference6>SASN20301</Reference6>
    				<ReferenceCode7>C07</ReferenceCode7>
    				<Reference7/>
    				<ReferenceCode8>25</ReferenceCode8>
    				<Reference8>PS</Reference8>
    				<ReferenceCode9/>
    				<Reference9/>
    				<ReferenceCode10/>
    				<Reference10/>
    				<ActionCode>19</ActionCode>
    			</PIXFields>
    		</PIX>
    				<PIX>
    			<TransactionType>300</TransactionType>
    			<TransactionCode>01</TransactionCode>
    			<TransactionNumber>14836</TransactionNumber>
    			<SequenceNumber>1</SequenceNumber>
    			<ItemDefinition>
    				<Style>2020</Style>
    				<StyleSuffix>CUIR1</StyleSuffix>
    				<SizeDesc>01</SizeDesc>
    			</ItemDefinition>
    			<SubItemFields>
    				<InventoryType>P</InventoryType>
    				<BatchNumber>A128348</BatchNumber>
    			</SubItemFields>
    			<PIXFields>
    				<DateCreated>04/16/20 19:44:22</DateCreated>
    				<InvAdjustmentQty>100</InvAdjustmentQty>
    				<UnitOfMeasure>M</UnitOfMeasure>
    				<InvAdjustmentType>S</InvAdjustmentType>
    				<Warehouse>FRM</Warehouse>
    				<TransReasonCode/>
    				<ReceiptsVariance/>
    				<UnitsShipped>1.5</UnitsShipped>
    				<UnitsReceived>30</UnitsReceived>
    				<ReferenceCode1>12</ReferenceCode1>
    				<Reference1>110350</Reference1>
    				<ReferenceCode2>C02</ReferenceCode2>
    				<Reference2>BL00001123</Reference2>
    				<ReferenceCode3>C03</ReferenceCode3>
    				<Reference3>2016-09-15 03:28:00.0</Reference3>
    				<ReferenceCode4>37</ReferenceCode4>
    				<Reference4/>
    				<ReferenceCode5>43</ReferenceCode5>
    				<Reference5/>
    				<ReferenceCode6>08</ReferenceCode6>
    				<Reference6>SASN20301</Reference6>
    				<ReferenceCode7>C07</ReferenceCode7>
    				<Reference7/>
    				<ReferenceCode8>25</ReferenceCode8>
    				<Reference8>PS</Reference8>
    				<ReferenceCode9/>
    				<Reference9/>
    				<ReferenceCode10/>
    				<Reference10/>
    				<ActionCode>19</ActionCode>
    			</PIXFields>
    		</PIX>
     
    				<PIX>
    			<TransactionType>300</TransactionType>
    			<TransactionCode>01</TransactionCode>
    			<TransactionNumber>14836</TransactionNumber>
    			<SequenceNumber>1</SequenceNumber>
    			<ItemDefinition>
    				<Style>2020</Style>
    				<StyleSuffix>CUIR1</StyleSuffix>
    				<SizeDesc>01</SizeDesc>
    			</ItemDefinition>
    			<SubItemFields>
    				<InventoryType>P</InventoryType>
    				<BatchNumber>A128348</BatchNumber>
    			</SubItemFields>
    			<PIXFields>
    				<DateCreated>04/16/20 19:44:22</DateCreated>
    				<InvAdjustmentQty>100</InvAdjustmentQty>
    				<UnitOfMeasure>Unit</UnitOfMeasure>
    				<InvAdjustmentType>S</InvAdjustmentType>
    				<Warehouse>FRM</Warehouse>
    				<TransReasonCode/>
    				<ReceiptsVariance/>
    				<UnitsShipped>1.5</UnitsShipped>
    				<UnitsReceived>30</UnitsReceived>
    				<ReferenceCode1>12</ReferenceCode1>
    				<Reference1>110350</Reference1>
    				<ReferenceCode2>C02</ReferenceCode2>
    				<Reference2>BL00001123</Reference2>
    				<ReferenceCode3>C03</ReferenceCode3>
    				<Reference3>2016-09-15 03:28:00.0</Reference3>
    				<ReferenceCode4>37</ReferenceCode4>
    				<Reference4/>
    				<ReferenceCode5>43</ReferenceCode5>
    				<Reference5/>
    				<ReferenceCode6>08</ReferenceCode6>
    				<Reference6>SASN20301</Reference6>
    				<ReferenceCode7>C07</ReferenceCode7>
    				<Reference7/>
    				<ReferenceCode8>25</ReferenceCode8>
    				<Reference8>PS</Reference8>
    				<ReferenceCode9/>
    				<Reference9/>
    				<ReferenceCode10/>
    				<Reference10/>
    				<ActionCode>19</ActionCode>
    			</PIXFields>
    		</PIX>
    	</Message>
    </tXML>


    Ce n'est donc pas le comportement que je souhaite. Il me semble que le fichier prend le premier PIX et applique les mêmes données sur les suivants sans distinctions.

    J'ai donc pensé à utiliser la balise :
    Code :Sélectionner tout -Visualiser dans une fenêtre à part
    <xsl:for-each select="/tXML/Message/PIX">
    afin d’effectuer la transformation PIX par PIX (tout en vérifiant si celui ci est éligible à une modification).
    J'ai tenté de la placer de diverses façons mais je n'ai jamais réussi à avoir le résultat souhaité donc je ne sais plus quoi faire...

    Pouvez vous m'aider svp ? Est-ce que la balise for each est la bonne manière de faire ? Si oui , où faut-il la placer ?


    Merci d'avance

  2. #2
    Membre émérite
    Je n'ai pas tout lu et de tous les détails, mais je pense à ce genre d'erreurs en général qui se fait souvent.
    Prenons le template pour UnitsReceived comme example: je le réérirerais comme suite. Je préfère parfois de le briser en deux templates plus spécifiques pour gainer un peu d'efficacité et de clarté, mais, on peut bien-entendu les combiner quelque peu comme vous avez fait et c'est valable aussi.
    Code xslt1 :Sélectionner tout -Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <xsl:template match="UnitsReceived[normalize-space(parent::PIXFields/UnitOfMeasure)='M']">
        <xsl:copy>
            <xsl:value-of select="number() * $var1"/>
        </xsl:copy>
    </xsl:template>
    <xsl:template match="UnitsReceived[normalize-space(parent::PIXFields/UnitOfMeasure)='M2']">
        <xsl:copy>
            <xsl:value-of select="number() * $var2"/>
        </xsl:copy>
    </xsl:template>

    Les mêmes pour UnitsShipped et InvAdjustmentQty.

  3. #3
    Candidat au Club
    Bonjour Tsuji ,

    Un grand merci ! Ta méthode fonctionne parfaitement !

    Merci beaucoup pour ton aide,

    Bonne journée