Funções XML no Jitterbit Studio
As funções XML são tipicamente usadas em scripts de mapeamento de transformação que requerem a manipulação e o acesso a dados XML.
Attribute
Declaração
type Attribute(string attributeName, string attributeValue)
Sintaxe
Attribute(<attributeName>, <attributeValue>)
Parâmetros obrigatórios
attributeName: Nome do atributoattributeValue: Valor do atributo
Descrição
Cria um atributo para um nó XML. Veja também a função CreateNode.
Exemplos
// Adiciona um atributo "name" com um valor de "value"
Attribute("name","value");
CreateNode
Declaração
string CreateNode(string namespace, string nodeName, type attributeSubelement[,...])
Sintaxe
CreateNode(<namespace>, <nodeName>, <attributeSubelement>[,...])
Parâmetros obrigatórios
namespace: O namespace do nónodeName: Nome do nóattributeSubelement: Um subelemento: um valor, atributo ou sub-nó
Parâmetros opcionais
attributeSubelement: Subelementos adicionais (um valor, atributo ou sub-nó), conforme necessário
Descrição
Cria uma string representando um nó XML. Se o nó alvo for o nó de valor de um nó XML Any, um elemento XML correspondente ao nodeName e nodeValue será criado.
A partir do terceiro argumento, uma série de valores, atributos e sub-nós pode ser especificada. Os valores são especificados diretamente. Atributos e sub-nós podem ser criados com as funções Attribute e CreateNode, respectivamente.
Exemplos
// Creates a node with a sub-node
CreateNode("http://example.com/xml",
"Contact", "Bill G.", Attribute("Type", "VIP"),
CreateNode("http://example.com/xml",
"Title", "Manager")
);
GetNodeName
Declaração
string GetNodeName(type path)
Sintaxe
GetNodeName(<path>)
Parâmetros obrigatórios
path: Uma expressão de caminho de referência em string que seleciona um único nó na transformação atual ou XML bruto.
Descrição
Recupera o nome de um nó. Este método é tipicamente utilizado para obter o nome de um nó retornado pelas funções SelectNodeFromXMLAny ou SelectSingleNode.
Para inserir um caminho para um nó na função para o parâmetro path, arraste e solte a pasta do nó XML desejado da aba Objetos de Origem do painel de componentes de script para o script, a fim de inserir seu caminho qualificado na localização do seu cursor, ou insira seu caminho de referência manualmente. Para mais informações, consulte as instruções sobre inserindo objetos de origem.
Exemplos
// Recupera o nome de um nó
GetNodeName(SelectNodeFromXMLAny("Account", Root$Any.));
GetNodeValue
Declaração
string GetNodeValue(type path)
Sintaxe
GetNodeValue(<path>)
Parâmetros obrigatórios
path: Uma expressão de caminho de referência em string que seleciona um único nó na transformação atual ou XML bruto.
Descrição
Recupera o valor de um nó. Este método é tipicamente utilizado para obter o valor de um nó retornado pelas funções SelectNodeFromXMLAny ou SelectSingleNode.
Para inserir um caminho para um nó na função para o parâmetro path, arraste e solte a pasta do nó XML desejado da aba Objetos de Origem do painel de componentes de script para o script, a fim de inserir seu caminho qualificado na localização do seu cursor, ou insira seu caminho de referência manualmente. Para mais informações, consulte as instruções sobre inserindo objetos de origem.
Exemplos
// XML definition
xmlInput = '<?xml version="1.0" encoding="UTF-8"?>
<root>
<father>
<child>
<name>John Smith</name>
<age>20</age>
</child>
<child>
<name>Jordan Coleman</name>
<age>32</age>
</child>
<child>
<name>Joel Parker</name>
<age>54</age>
</child>
<child>
<name>Roger Wright</name>
<age>28</age>
</child>
</father>
</root>';
// Retrieve the name of the second child:
exampleArray = GetNodeValue(SelectNodes(xmlInput, "/root/father/child[position() = 2]/name"));
result = exampleArray[0];
// Equals "Jordan Coleman"
// Recupera o valor de um nó
GetNodeValue(SelectNodeFromXMLAny("Account", Root$Any.));
GetXMLString
Declaração
string GetXMLString(type path[, bool qualified])
Sintaxe
GetXMLString(<path>[, <qualified>])
Parâmetros obrigatórios
path: Uma expressão de caminho de referência de string que seleciona um único nó na transformação atual. O caminho definido deve ser para um nó; campos e atributos específicos são ignorados durante a avaliação do caminho.
Parâmetros opcionais
qualified: Um valor booleano (padrãofalse); quando qualificado (true), a string XML retornada é mais fácil de ler, mas pode não ser válida XML por si só.
Descrição
Retorna (quando usado em um mapeamento de transformação) a string XML correspondente encontrada no documento XML de origem no caminho especificado.
Para inserir um caminho para um nó na função para o parâmetro path, arraste e solte a pasta do nó XML desejado da aba Objetos de Origem do painel de componentes de script para o script para inserir seu caminho qualificado na localização do seu cursor, ou insira seu caminho de referência manualmente. Para mais informações, consulte as instruções sobre inserindo objetos de origem.
Nota
O caminho definido deve ser para um nó; campos e atributos específicos são ignorados durante a avaliação do caminho.
Exemplos
// Recupera a string XML correspondente no caminho especificado
GetXMLString([Header$DETAIL.]);
// Recupera a string XML correspondente no caminho especificado
GetXMLString([root$transaction.response$body$queryResponse$result$records.Case$Account$]);
IsNil
Declaração
bool IsNil(string path)
Sintaxe
IsNil(<path>)
Parâmetros obrigatórios
path: Uma expressão de caminho de referência de string que seleciona um único nó na transformação atual
Descrição
Retorna (quando usado em um mapeamento do Construtor de Fórmulas) se o nó XML correspondente possui o atributo "xsi:nil" com o valor true (ou 1).
Para inserir um caminho para um nó na função para o parâmetro path, arraste e solte a pasta do nó XML desejado da aba Objetos de Origem da paleta do componente de script para o script para inserir seu caminho qualificado na localização do seu cursor, ou insira seu caminho de referência manualmente. Para mais informações, consulte as instruções sobre inserindo objetos de origem.
Conforme descrito no XML Schema, um elemento pode ser válido sem conteúdo se tiver o atributo xsi:nil com o valor true.
Exemplos
// Retorna se o nó é nil
IsNil("Header$DETAIL.");
RunXSLT
Declaração
array RunXSLT(string xslt, string xml1[, string xml2,... string xmlN)
Sintaxe
RunXSLT(<xslt>, <xml1>[, <xml2>,... <xmlN>])
Parâmetros obrigatórios
xslt: Um caminho de referência de string para uma atividade associada a um endpoint do tipo arquivo no projeto atual que retorna uma folha de estilo XSLTxml1...xmlN: Um caminho de referência de string para uma atividade associada a um endpoint do tipo arquivo no projeto atual que retorna um ou mais documentos XML
Descrição
Suporta a execução de XSLT (v1-3) em vários documentos XML de entrada. Recebe como entrada uma folha de estilo XSLT e um ou mais documentos XML, retornando um array de documentos XML.
O parâmetro xslt utilizado nesta chamada de função deve ser definido como uma atividade associada a um endpoint do tipo arquivo no projeto atual que retorna uma folha de estilo XSLT. Os parâmetros xml1...xmlN utilizados nesta chamada de função devem ser definidos como uma ou mais atividades associadas a endpoints do tipo arquivo no projeto atual que retornam um ou mais documentos XML. Isso inclui atividades configuradas de Compartilhamento de Arquivos, FTP, HTTP, Armazenamento Local e Armazenamento Temporário. Para mais informações, consulte as instruções sobre inserir endpoints.
Se suas folhas de estilo XSLT contiverem instâncias de JSON aninhado incorporado que precisam ser preservadas, defina a variável jitterbit.transformation.ignore_default_value como true antes desta função. Esta variável é suportada ao usar agentes 11.36 e posteriores.
Referindo-se a arquivos de dentro de uma folha de estilo XSLT
Embora o Jitterbit tenha amplo suporte para XSLT, projetos que utilizam XSLT devem seguir regras para atender aos padrões de segurança. Essas regras significam que o acesso a arquivos ou URIs deve sempre ser feito por meio de atividades definidas no mesmo projeto.
Para referenciar esses arquivos ou URIs em uma folha de estilo, use a função XLST fn:doc e especifique 'param1' para a primeira entrada XML, 'param2' para a segunda entrada XML e assim por diante para cada arquivo XML adicional.
Dado o exemplo de processamento de três arquivos XML (customers, salesPeople, salesOrders), você poderia referenciá-los em uma folha de estilo XSLT usando:
<xsl:for-each select="doc('param1')/*:Customers/*:SalesOrder[customer_external_id!=''][sales_person_external_id!='']">
...
<xsl:for-each select="doc('param2')/*:SalesPeople/*:Account[*:customer_id/string(number(text()))=$CustomerExtId][1]">
...
<xsl:for-each select="doc('param3')/*:SalesOrders/*:SalesOrder[customer_external_id!=''][sales_person_external_id!='']">
Se você tiver um único arquivo XML de entrada, não é necessário usar a sintaxe doc('param1'), pois o Jitterbit definirá o contexto inicial para esse único arquivo.
Especificando um modelo inicial na folha de estilo
Em algumas situações, o Jitterbit precisa saber onde em uma folha de estilo começar o processamento. Isso é alcançado incluindo na folha de estilo um modelo com o nome específico de start_here:
<xsl:template name="start_here" match="/">
Exemplos
// Running XSLT on XML Files
// Read in a stylesheet
xslt = ReadFile("<TAG>activity:ftp/FTP Endpoint/ftp_read/XSLT</TAG>");
// Read in two XML files for processing
xml1 = ReadFile("<TAG>activity:ftp/FTP Endpoint/ftp_read/XML1</TAG>");
xml2 = ReadFile("<TAG>activity:ftp/FTP Endpoint/ftp_read/XML2</TAG>");
// RunXSLT on the stylesheet and the two XML files
output = RunXSLT(xslt, xml1, xml2);
// As RunXSLT() returns an array,
// retrieve the output from each element
i = 0;
While(i < Length(output),
// Write output to a file
WriteFile("<TAG>activity:ftp/FTP Endpoint/ftp_write/XML Output FTP</TAG>",
output[i], "output" + (i+1) + ".xml");
i++;
);
SelectNodeFromXMLAny
Declaração
type SelectNodeFromXMLAny(string nodeName, type anyNodes)
Sintaxe
SelectNodeFromXMLAny(<nodeName>, <anyNodes>)
Parâmetros obrigatórios
nodeName: O nome do nó desejadoanyNodes: O caminho do elemento de dados de um nó de valor de um elemento XML Any, uma expressão de caminho de referência de string para um array de nós XML na transformação atual, ou XML bruto
Descrição
Retorna o primeiro nó XML de uma lista de nós XML Any que correspondem ao nome do nó.
Para inserir um caminho para um array de nós XML na função para o parâmetro anyNodes, arraste e solte a pasta do nó XML desejado da aba Objetos de Origem do painel de componentes de script para o script para inserir seu caminho qualificado na localização do seu cursor, ou insira seu caminho de referência manualmente. Para mais informações, consulte as instruções sobre inserindo objetos de origem.
Exemplos
// Procura o primeiro nó que corresponde a "Account"
SelectNodeFromXMLAny("Account", Root$Any#.);
SelectNodes
Declaração
array SelectNodes(type node, string xPathQuery[, string xPathArg1,... string xPathArgN])
Sintaxe
SelectNodes(<node>, <xPathQuery>[, <xPathArg1>,... <xPathArgN>])
Parâmetros obrigatórios
node: Uma expressão de caminho de referência em string para o nó desejado na transformação atual, um fragmento XML para executar a consulta ou XML brutoxPathQuery: O caminho do elemento de dados de um nó de valor de um elemento XML Any
Parâmetros opcionais
xPathArg1...xPathArgN: Prefixos que especificam os namespaces dos nós na consulta XPath
Descrição
Executa uma consulta XPath (veja o padrão XPath, v1-v3) em um fragmento XML ou em um nó XML retornado de outra função, e retorna os resultados da consulta.
Se os prefixos opcionais forem usados para especificar os namespaces do nó na consulta XPath, os prefixos devem ser especificados como um ou mais argumentos de string após o XPath (veja o segundo exemplo).
Para inserir um caminho para um nó na função para o parâmetro node, arraste e solte a pasta do nó XML desejado da aba Objetos de Origem do painel de componentes de script para o script para inserir seu caminho qualificado na localização do seu cursor, ou insira seu caminho de referência manualmente. Para mais informações, veja as instruções sobre inserir objetos de origem.
Para suportar caracteres HTML, defina jitterbit.decode.html.chars como true antes desta função. Esta variável é suportada com dados de string ao usar agentes 10.49 e posteriores.
Exemplos
// XML definition
xmlInput = '<?xml version="1.0" encoding="UTF-8"?>
<root>
<father>
<child>
<name>John Smith</name>
<age>20</age>
</child>
<child>
<name>Jordan Coleman</name>
<age>32</age>
</child>
<child>
<name>Joel Parker</name>
<age>54</age>
</child>
<child>
<name>Roger Wright</name>
<age>28</age>
</child>
</father>
</root>';
// Retrieve all the XML nodes that match the XPath query:
SelectNodes(xmlInput, "/root/father/child");
// Returns {"<child> <name>John Smith</name> <age>20</age> </child>","<child> <name>Jordan Coleman</name> <age>32</age> </child>","<child> <name>Joel Parker</name> <age>54</age> </child>","<child> <name>Roger Wright</name> <age>28</age> </child>"}
// Retrieve a range of nodes using a position argument with the XPath query:
SelectNodes(xmlInput, "/root/father/child[position() > 2 and position() <= 4]");
// Returns {"<child> <name>Joel Parker</name> <age>54</age> </child>","<child> <name>Roger Wright</name> <age>28</age> </child>"}
// XML definition with root namespace
xmlInput = '<?xml version="1.0" encoding="UTF-8"?>
<ns0:root xmlns:ns0="urn:ean.ucc:align:2">
<father>
<child>
<name>John Smith</name>
<age>20</age>
</child>
<child>
<name>Jordan Coleman</name>
<age>32</age>
</child>
<child>
<name>Joel Parker</name>
<age>54</age>
</child>
<child>
<name>Roger Wright</name>
<age>28</age>
</child>
</father>
</ns0:root>';
// Retrieve all the XML nodes that match the XPath query with a namespace considered:
SelectNodes(xmlInput, "/ns0:root/father/child", "ns0=urn:ean.ucc:align:2");
// Returns {"<child> <name>John Smith</name> <age>20</age> </child>","<child> <name>Jordan Coleman</name> <age>32</age> </child>","<child> <name>Joel Parker</name> <age>54</age> </child>","<child> <name>Roger Wright</name> <age>28</age> </child>"}
// Connects to an LDAP server, runs a search,
// and then runs an XPath query on the results
LDAPConnect("directory.company.example.com","ghvwright","1LikesPe@ches",0);
searchResults = LDAPSearch("CN=Users,DC=company,DC=example,DC=com",
"(&(objectCategory=person)(objectClass=user))", 1,
"name", "whenCreated", "description", "telephoneNumber");
resultNodes = SelectNodes(searchResults,
"/DirectoryResults/Entry[name='Administrator']/whenCreated" );
SelectNodes(Root$Any$,
"ns1:E2/ns2:E3",
"ns1=http://xyz1.example.com/",
"ns2=http://xyz2.example.com/");
Nota
Neste segundo exemplo, o nó de referência é um nó XML para um nó XML Any. Na consulta XPath, ns1:E2 não é o próprio nó de referência.
Desde que os prefixos ns1 e ns2 são usados na consulta XPath, eles são definidos como argumentos adicionais após o XPath.
SelectNodesFromXMLAny
Declaração
array SelectNodesFromXMLAny(string xPathQuery, type anyNodes[, string xPathArg1,... string xPathArgN])
Sintaxe
SelectNodesFromXMLAny(<xPathQuery>, <anyNodes>[, <xPathArg1>,... <xPathArgN>])
Parâmetros obrigatórios
xPathQuery: Uma consulta XPathanyNodes: O caminho do elemento de dados de um nó de valor de um elemento XML Any, uma expressão de caminho de referência de string para um array de nós XML na transformação atual, ou XML bruto
Parâmetros opcionais
xPathArg1...xPathArgN: Prefixos que especificam os namespaces dos nós na consulta XPath
Descrição
Retorna um array de todos os nós XML que são correspondidos por uma consulta XPath (veja o padrão XPath, v1-v3) executada contra um caminho de um nó de valor de um elemento XML Any ou um array de nós XML.
Se os prefixos opcionais forem usados para especificar os namespaces do nó na consulta XPath, os prefixos devem ser especificados como um ou mais argumentos de string após o XPath (veja o segundo exemplo).
Para inserir um caminho para um array de nós XML na função para o parâmetro anyNodes, arraste e solte a pasta do nó XML desejado da aba Objetos de Origem do painel de componentes de script para o script para inserir seu caminho qualificado na localização do seu cursor, ou insira seu caminho de referência manualmente. Para mais informações, veja as instruções sobre inserindo objetos de origem.
Exemplos
// Seleciona todos os nós com os nomes dados
SelectNodesFromXMLAny("Account|Customer|Name", Root$Any#.);
// Selecione apenas endereços de email e números de telefone
$nodes = SelectNodesFromXMLAny("cust:EmailAddress|cust:PhoneNumber",
Customer$Any#., "cust=urn:xmlns:25hoursaday-com:customer");
SelectSingleNode
Declaração
type SelectSingleNode(type node, string xPath,...)
Sintaxe
SelectSingleNode(<node>, <xPath>,...)
Parâmetros obrigatórios
-
node: Uma expressão de caminho de referência em string para o nó desejado na transformação atual, um fragmento XML para executar a consulta ou XML bruto -
xPathQuery: O caminho do elemento de dados de um nó de valor de um elemento XML Any
Parâmetros opcionais
xPathArg1...xPathArgN: Prefixos que especificam os namespaces dos nós na consulta XPath
Descrição
Executa uma consulta XPath (veja o padrão XPath, v1-v3) em um fragmento XML ou em um nó XML retornado de outra função, e retorna o primeiro nó nos resultados da consulta.
Se os prefixos opcionais forem usados para especificar os namespaces do nó na consulta XPath, os prefixos devem ser especificados como um ou mais argumentos de string após o XPath (veja o segundo exemplo).
Para inserir um caminho para um nó na função para o parâmetro node, arraste e solte a pasta do nó XML desejado da aba Objetos de Origem da paleta do componente de script para o script para inserir seu caminho qualificado na localização do seu cursor, ou insira seu caminho de referência manualmente. Para mais informações, veja as instruções sobre inserindo objetos de origem.
Para suportar caracteres HTML, defina jitterbit.decode.html.chars como true antes desta função. Esta variável é suportada com dados de string ao usar agentes 10.49 e posteriores.
Exemplos
// XML definition
xmlInput = '<?xml version="1.0" encoding="UTF-8"?>
<root>
<father>
<child>
<name>John Smith</name>
<age>20</age>
</child>
<child>
<name>Jordan Coleman</name>
<age>32</age>
</child>
<child>
<name>Joel Parker</name>
<age>54</age>
</child>
<child>
<name>Roger Wright</name>
<age>28</age>
</child>
</father>
</root>';
// Retrieve the first matching node given an XPath query:
SelectSingleNode(xmlInput, "/root/father/child");
// Returns <child> <name>John Smith</name> <age>20</age> </child>
// Connects to an LDAP server, runs a search,
// runs an XPath query on the results, and
// selects the first node in the query results
LDAPConnect("directory.company.example.com", "ghvwright", "1LikesPe@ches", 0);
searchResults = LDAPSearch("CN=Users,DC=company,DC=example,DC=com",
"(&(objectCategory=person)(objectClass=user))", 1, "name",
"whenCreated", "description", "telephoneNumber");
resultNode = SelectSingleNode(searchResults,
"/DirectoryResults/Entry[name='Administrator']/whenCreated");
// Selects the first node in an XPath query result.
// The reference node is an XML node for an XML Any node.
// In the XPath query, "ns1:E2" is not the reference node itself.
// Since the prefixes ns1 and ns2 are used in the XPath query,
// they are defined as additional arguments after the XPath.
SelectSingleNode(Root$Any$,
"ns1:E2/ns2:E3",
"ns1=http://xyz1.example.com",
"ns2=http://xyz2.example.com/");