- 16.7.1. Dados do Produto
16.7.1.2. Detalhe dos Produtos e Serviços 2G - 16.7.1.1. Detalhe dos Produtos e Serviços
« Anterior - 16.7.1.3. Informações da DI
Próximo »
16.7.1.2. Detalhe dos Produtos e Serviços 2G
Funcionalidade para gerar o XML do grupo do detalhamento de produtos e Serviços da NF-e 2G
Assinatura
string produto2G(string cProd, string cEAN, string xProd, string NCM, string EXTIPI, int CFOP, string uCom, double qCom, double vUnCom, double vProd, string cEANTrib, string uTrib, double qTrib, double vUnTrib, double vFrete, double vSeg,double vDesc, double vOutro, int indTot, string DI, string DetEspecifico, string xPed, int nItemPed);
Descrição:
Funcionalidade para gerar o XML do grupo do detalhamento de produtos e Serviços da NF-e na versão 2.00 do leiaute da NF-e.
Parâmetros:
| nome | tipo | tam. | obrig. | descrição |
|---|---|---|---|---|
| cProd | string | 1-60 | sim | informar o código do produto ou serviço. Preencher com CFOP, caso se trate de itens não relacionados com mercadorias/produtos e que o contribuinte não possua codificação própria. Formato ”CFOP9999”. |
| cEAN | string | 0,8,12,13,14 | sim | informar o GTIN (Global Trade Item Number) do produto, antigo código EAN ou código de barras. Preencher com o código GTIN-8, GTIN-12, GTIN-13 ou GTIN-14 (antigos códigos EAN, UPC e DUN-14), não informar o conteúdo da TAG em caso de o produto não possuir este código. |
| xProd | string | 1-120 | sim | informar a descrição do produto ou serviço. |
| NCM | string | 2,8 | não | informar o Código NCM com 8 dígitos; informar a posição do capítulo do NCM (as duas primeiras posições do NCM) quando a operação não for de comércio exterior (importação/ exportação) ou o produto não seja tributado pelo IPI; se for serviços, informar 00. (campo alterado para ser obrigatório) |
| EXTIPI | string | 2,3 | não | informar de acordo com o código EX da TIPI se houver para o NCM do produto. |
| CFOP | inteiro | 4 | sim | informar o CFOP - Código Fiscal de Operações e Prestações. |
| uCOM | string | 1-6 | sim | informar a unidade de comercialização do produto (Ex. pc, und, dz, kg, etc.). |
| qCOM | string | 15,4 | sim | informar a quantidade de comercialização do produto já formatado com ponto decimal. A quantidade de casas decimais pode variar de 0 a 4. (tamanho e tipo do campo alterado) |
| vUnCOM | string | 21,10 | sim | Informar o valor unitário de comercialização do produto já formatado com ponto decimal, campo meramente informativo, o contribuinte pode utilizar a precisão desejada (0-10 decimais). Para efeitos de cálculo, o valor unitário será obtido pela divisão do valor do produto pela quantidade comercial. (tamanho e tipo do campo alterado) |
| vProd | duplo | 15,2 | sim | informar o valor total bruto do produto ou serviços. |
| cEANTrib | string | 0,8,12,13,14 | sim | informar o GTIN (Global Trade Item Number) da unidade de tributação do produto, antigo código EAN ou código de barras. Preencher com o código GTIN-8, GTIN-12, GTIN-13 ou GTIN-14 (antigos códigos EAN, UPC e DUN-14), não informar o conteúdo da TAG em caso de o produto não possuir este código. |
| uTrib | string | 1-6 | sim | informar a unidade de tributação do produto (Ex. pc, und, dz, kg, etc.). |
| qTrib | string | 15,4 | sim | informar a quantidade de tributação do produto já formatado com ponto decimal. A quantidade de casas decimais pode variar de 0 a 4. (tamanho e tipo do campo alterado) |
| vUnTrib | string | 21,10 | sim | Informar o valor unitário de tributação do produto já formatado com ponto decimal, campo meramente informativo, o contribuinte pode utilizar a precisão desejada (0-10 decimais). Para efeitos de cálculo, o valor unitário será obtido pela divisão do valor do produto pela quantidade tributável. (tamanho e tipo do campo alterado) |
| vFrete | duplo | 15,2 | não | informar o valor do Frete, o Frete deve ser rateado entre os itens de produto. |
| vSeg | duplo | 15,2 | não | informar o valor do Seguro, o Seguro deve ser rateado entre os itens de produto. |
| vDesc | duplo | 15,2 | não | informar o valor do desconto do item de produto ou serviço. |
| vOutro | duplo | 15,2 | não | informar o valor de outras despesas acessórias do item de produto ou serviço. (campo novo) |
| indTot | inteiro | - | sim | Este campo deverá ser preenchido com: 0 - o valor do item (vProd) não compõe o valor total da NF-e (vProd) 1 - o valor do item (vProd) compõe o valor total da NF-e. (campo novo) |
| DI | string | - | não | informar o XML do grupo DI - dados da importação nas operações de importação. |
| DetEspecifico | string | - | não | informar o XML do grupo veicProd - detalhamento de específico de veículos novos ou com o XML do grupo med - detalhamento de específico de medicamentos ou com o XML do grupo arma - detalhamento de específico de armamentos ou com o XML do grupo comb - detalhamento de específico de combustíveis e lubrificantes. |
| xPed | string | 1-15 | não | informar o número do pedido de compra, o campo é de livre uso do emissor. (campo novo) |
| nItemPed | inteiro | - | não | informar o número do item do pedido de compra, o campo é de livre uso do emissor. (campo novo) |
Importante
Os tipos dos parâmetros: qCom, qTrib, vUnCom e vUnTrib foram alterados para string, pois a quantidade de casas decimais passou a ser variável. Para dar maior flexibilidade, o usuário já deve passar os valores com a quantidade de casas decimais que desejar para a DLL, vale observar que o ponto decimal deve ser o ponto decimal.
Diagrama:

Dica
Os campos com contorno tracejado podem ser omitidos se a operação não exigir a informação.
Os grupos XML veicProd (detalhamento específico de veículos novos), med (detalhamento específico de medicamentos e insumos), arma (detalhamento específico de armamentos) e comb (detahamento específico de combustíveis e lubrificantes) são grupos XML que devem ser gerados em separado e são mutuamente exclusivos. Apenas um deles deve ser informado no parâmetro DetEspecifico.
Retorno:
Um string com o grupo XML do detalhe do Produto ou Serviço
XML:
Exemplo de XML do produto simples
<prod> <cProd>00001</cProd> <cEAN/> <xProd>Agua Mineral</xProd> <NCM>25</NCM> <CFOP>5101</CFOP> <uCom>dz</uCom> <qCom>1000</qCom> <vUnCom>1</vUnCom> <vProd>1000.00</vProd> <cEANTrib/> <uTrib>und</uTrib> <qTrib>12000</qTrib> <vUnTrib>1</vUnTrib> <intTot>1</intTot> </prod>
Exemplo de XML do produto com detalhamento específico de medicamento
<prod> <cProd>402729</cProd> <cEAN>7891058008628</cEAN> <xProd>DORFLEX 24X10 CP CH</xProd> <NCM>30049012</NCM> <genero>30</genero> <CFOP>5409</CFOP> <uCom>CX</uCom> <qCom>2</qCom> <vUnCom>25.4850</vUnCom> <vProd>50.97</vProd> <cEANTrib>7891058008628</cEANTrib> <uTrib>CX</uTrib> <qTrib>2</qTrib> <vUnTrib>25.4850</vUnTrib> <intTot>1</intTot> <med> <nLote>602958</nLote> <dVal>2008-05-01</dVal> <vPMC>80.73</vPMC> </med> </prod>
Importante
O trecho do XML foi formatado para uma melhor visualização, a mensagem original não tem formatação.
Vale observar que a formatação pode corromper a assinatura digital, além de ocupar espaço e ser desnecessária, pois os browser exibem formatado.
Exemplos de uso:
Visual Basic 6.0
' inicializar variáveis '............................................... Dim objNFeUtil As NFe_Util_2G.Util Set objNFeUtil = New NFe_Util_2G.Util ' ' '================grupo de detalhe do produto (grupo I01 do Manual de integração - páginas 95)======================= ' ' Prod_cProd = "001152" ' código do produto Prod_cEAN = "7897844200115" ' código EAN (0, 8,12, 13 ou 14 caracteres), o conteúdo pode ser omitido se não tiver EAN Prod_xProd = "Cola Especial para EPS" ' código do produto, espaços em branco consecutivos ou no início ou fim do campo podem ' gerar erro de Schema XML, além de caracteres reservados do XML <>&"' Prod_NCM = "35" ' código NCM, pode informar somente a posição do capítulo se a operação não for sujeito ao IPI. Prod_ExTIPI = "" ' ExTipi, informar de acordo com o código EX da TIPI se houver para o NCM do produto. Prod_CFOP = "5102" ' CFOP do operação, causa erro de XML se informado um código inexistente Prod_uCOM = "UN" ' unidade de comercialização Prod_qCom = "10" ' quantidade de comercialização Prod_vUnCom = "1" ' valor unitário de comercialização, campo de mera demonstração deve ser o resultado da ' da divisão do vProd / qCom Prod_vProd = 10 ' valor do total do item Prod_cEANTrib = "7897844200115" ' código EAN (0, 8,12, 13 ou 14 caracteres), o conteúdo pode ser omitido se não tiver EAN, ' em geral é o mesmo código do EAN de comercialização Prod_uTrib = "UN" ' unidade de tributação, na maioria dos casos é idêntico ao vUnCom, pode diferente nos ' casos de produtos sujeitos a ST em que a unidade de pauta é diferente da unidade de ' comercialização ' Ex. unidade de comercialização = 1 pack de lata de cerveja => unidade de tributação = ' 1 lata (preço de pauta) Prod_qTrib = "10" ' quantidade de comercialização Prod_vUnTrib = "1" ' valor unitário de tributação, campo de mera demonstração deve ser o resultado da ' divisão do vProd / qTrib Prod_vFrete = 0 ' valor do frete, se cobrado do cliente deve ser rateado entre os itens de produto Prod_vSeguro = 0 ' valor do seguro, se cobrado do cliente deve ser rateado entre os itens de produto Prod_vDesc = 0 ' valor do desconto concedido Prod_vOutro = 0 ' valor de outras despesas Prod_indTot = 1 ' indicador se o valor do item será totalizado no valor total dos produtos Prod_DI = "" ' dados da importação, informar apenas no caso de NF de entrada (importação), para montar ' o grupo utilize a funcionalidade DI Prod_DetEspecifico = "" ' dados específicos, informar para medicamento, veículos novos, armamentos e ' combustíveis, para montar o grupo utilizar a funcionalidade correspondente Prod_xPed = "" ' número do pedido, uso exclusivo do usuário Prod_nItemPed = 0 ' número do item do pedido, uso exclusivo do usuário ' ' gera grupo do produto ' prod = objNFeUtil.produto2G(Prod_cProd, Prod_cEAN, Prod_xProd, Prod_NCM, Prod_ExTIPI, Prod_CFOP, Prod_uCOM, Prod_qCom, Prod_vUnCom, Prod_vProd, Prod_cEANTrib, Prod_uTrib, Prod_qTrib, Prod_vUnTrib, Prod_vFrete, Prod_vSeguro, Prod_vDesc, Prod_vOutro, Prod_indTot, Prod_DI, Prod_DetEspecifico, Prod_xPed, Prod_nItemPed)
Importante
Se houver mais de um item de detalhe, o usuário deve concatenar os detalhes.
- 16.7.1.2. Detalhe dos Produtos e Serviços 2G
16.7.1. Dados do Produto - « Anterior
16.7.1.1. Detalhe dos Produtos e Serviços - Próximo »
16.7.1.3. Informações da DI