Jump to content
rtavix

[Resolvido] Erro no log de mensagem para usuário

Recommended Posts

Ao compilar meu código o mesmo me retorna o seguinte erro de log:

 

O CPF/CNPJ informado na célula H referente a linha 1 está em um formato incorreto. Favor corrigir a planilha. 
O CPF/CNPJ informado na célula H referente a linha 1 está em um formato incorreto. Favor corrigir a planilha. 
O CPF/CNPJ informado na célula H referente a linha 1 está em um formato incorreto. Favor corrigir a planilha. 
O CPF/CNPJ informado na célula H referente a linha 1 está em um formato incorreto. Favor corrigir a planilha. 
O CPF/CNPJ informado na célula H referente a linha 1 está em um formato incorreto. Favor corrigir a planilha. 
O CPF/CNPJ informado na célula H referente a linha 1 está em um formato incorreto. Favor corrigir a planilha. 
O CPF/CNPJ informado na célula H referente a linha 1 está em um formato incorreto. Favor corrigir a planilha. 
O CPF/CNPJ informado na célula H referente a linha 1 está em um formato incorreto. Favor corrigir a planilha. 
O CPF/CNPJ informado na célula H referente a linha 1 está em um formato incorreto. Favor corrigir a planilha. 

 

Entretanto o mesmo mostra linha 1 por diversas vezes, o certo era receber linha 1, linha 2, linha 3 assim por diante, alguém pode me ajudar por gentileza?

 

Segue meu código abaixo:

 private Interessado setInteressado(DataRow linha)
        {
            if (!linha.ItemArray[12].ToString().Equals(""))
                interessado.Cep = linha.ItemArray[12].ToString();
            if (!linha.ItemArray[7].ToString().Equals(""))
                if (linha.ItemArray[7].ToString().Length == 14)
                {
                    interessado.CPF_CNPJ = AuxiliarCPF_CNPJ.DesformataCPF(linha.ItemArray[7].ToString());
                    interessado.Tipo = 1;
                }
                else if (linha.ItemArray[7].ToString().Length == 18)
                {
                    interessado.CPF_CNPJ = AuxiliarCPF_CNPJ.DesformataCNPJ(linha.ItemArray[7].ToString());
                    interessado.Tipo = 2;
                }
                else
                {
                    int i = 0; 
                    i = i + 1; //uso para receber a proxima linha
                    log.Append("O CPF/CNPJ informado na célula H referente a linha " + (i) + " está em um formato incorreto. Favor corrigir a planilha. <br>");
                    arquivoInvalidado = true;
                }
            
            return interessado;
        }
}

 

Share this post


Link to post
Share on other sites

Eu te disse em outro tópico, sua lógica aqui não faz sentido algum. Esse código vai sempre dar 1:

int i = 0; 
i = i + 1; //uso para receber a proxima linha

Você terá que informar o número da linha quando chamar o método:

private Interessado setInteressado(DataRow linha, int indiceLinha)

E no seu else:

 

else 
{ 
log.Append("O CPF/CNPJ informado na célula H referente a linha " + indiceLinha.ToString() + " está em um formato incorreto. Favor corrigir a planilha. <br>"); 
arquivoInvalidado = true; 
}

 

Share this post


Link to post
Share on other sites
Em 4/16/2018 at 08:50, quintelab disse:

Eu te disse em outro tópico, sua lógica aqui não faz sentido algum. Esse código vai sempre dar 1:


int i = 0; 
i = i + 1; //uso para receber a proxima linha

Você terá que informar o número da linha quando chamar o método:


private Interessado setInteressado(DataRow linha, int indiceLinha)

E no seu else:

 


else 
{ 
log.Append("O CPF/CNPJ informado na célula H referente a linha " + indiceLinha.ToString() + " está em um formato incorreto. Favor corrigir a planilha. <br>"); 
arquivoInvalidado = true; 
}

 

Oi amigo, então segui tua orientação e alterei conforme na imagem abaixo:

 

Alteração 1.jpg

Alteração 2.jpg

 

Daí quando realizo a alteração amigo, dentro do meu método de Verificação preliminar, me retorna erro na linha setInteressado(linha); informando que :

No overload for methodo 'setInteressado' takes 1 arguments

Share this post


Link to post
Share on other sites
4 minutos atrás, quintelab disse:

Agora você precisa informar o indice da linha pro seu método. Qual a parte do código que chama esse método ?

Então, apos a sua sugestão e aplicada, no meu método abaixo:

 

 private void VerificacaoPreliminar(IEnumerable<DataRow> dados)
        {
            int i = 0;

            bool importado = false;
            foreach (var linha in dados)
            {
                i = i + 1;
                //Verifica se nenhuma planilha com o numSEP informado já não foi importada                
                if (!linha.ItemArray[17].ToString().Equals(""))
                {
                    if (aplProcessoInteressado.listaProcInterPorCodSep(decimal.Parse(linha.ItemArray[17].ToString())).Count != 0)
                    {
                        importado = true;
                        break;
                    }
                }
                else
                {
                    log.Append("A célula S referente a linha " + (i) + " deve ser preenchida. <br>");
                    arquivoInvalidado = true;
                }

                if (!importado)
                {
                    //Validação de campos obrigatórios                
                    if (linha.ItemArray[6].ToString().Equals(""))
                    {

                        log.Append("A célula G referente a linha " + (i) + " deve ser preenchida. <br>");
                        arquivoInvalidado = true;
                    }
                    if (linha.ItemArray[7].ToString().Equals(""))
                    {
                        log.Append("A célula H referente a linha " + (i) + " deve ser preenchida. <br>");
                        arquivoInvalidado = true;
                    }
                    if (linha.ItemArray[14].ToString().Equals(""))
                    {
                        log.Append("A célula O referente a linha " + (i) + " deve ser preenchida. <br>");
                        arquivoInvalidado = true;
                    }

                    //Valida se pelo menos uma das colunas de NumProcesso está preenchida
                    if (linha.ItemArray[1].ToString() == "" && linha.ItemArray[2].ToString() == "")
                    {
                        log.Append("A célula B referente a linha " + (i) + " e / ou célula C referente a linha " + (i) + " devem estar preenchidas. <br>");
                        arquivoInvalidado = true;
                    }

                    //Valida se a vara e comarca estão preenchidas no arquivo                                 
                    if (linha.ItemArray[3].ToString().Equals(""))
                    {
                        log.Append("A célula D referente a linha " + (i) + " deve ser preenchida. <br>");
                        arquivoInvalidado = true;
                    }
                    if (linha.ItemArray[5].ToString().Equals(""))
                    {
                        log.Append("A célula F referente a linha " + (i) + " deve ser preenchida. <br>");
                        arquivoInvalidado = true;
                    }
                    //Valida a consistencia da vara, comarca e numvara.
                    if (!linha.ItemArray[3].ToString().Equals("") &&
                        !linha.ItemArray[5].ToString().Equals(""))
                    {
                        List<VaraExecucao> listaVaraComarca = aplVaraExecucao.Consultar---omeVaraNomeComarca(linha.ItemArray[5].ToString().Trim(), linha.ItemArray[3].ToString().Trim());
                        if (listaVaraComarca.Count == 0)
                        {
                            log.Append("No sistema não existe vara de execução associada a comarca informada na linha " + (i) + ". Favor corrigir o sistema. <br>");
                            arquivoInvalidado = true;
                        }
                        else
                        {
                            VaraExecucao vara = new VaraExecucao();
                            if (linha.ItemArray[4].ToString().Equals(""))
                            {
                                vara = listaVaraComarca.Find(o => o.NumeroVara == null);
                            }
                            else
                            {
                                vara = listaVaraComarca.Find(o => o.NumeroVara == int.Parse(linha.ItemArray[4].ToString().Trim()));
                            }
                            if (vara == null || vara.Codigo == 0)
                            {
                                log.Append("O número da vara informado na célula E referente a linha " + (i) + " não corresponde a vara e comarca informada. Favor corrigir o sistema ou a planilha. <br>");
                                arquivoInvalidado = true;
                            }
                        }
                    }

                    setInteressado(linha);// Dá erro aqui

                }
            }
            if (importado)
            {
                log.Append("Uma planilha com o Nº SEP informado já foi importada. <br>");
                arquivoInvalidado = true;
            }
        }

Dá o erro no setInteressado após a alteração, dizendo que o nome indiceLinha não existe no current context.

Share this post


Link to post
Share on other sites
14 minutos atrás, quintelab disse:

Basta você passar o número da sua linha pra esse método.

 


setInteressado(linha, i);// Dá erro aqui

Dica: procure algum curso de c#
Algumas video aulas vão te ajudar com alguns pontos básicos.

Brother, como eu disse eu sou iniciante, estou me esforçando, irei começar um cursinho no senac o mês que vem, mas te agradeço ai pelas dicas, mas gostaria de informar que já consegui resolver. Muito obrigado!

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By rdavisp
      Senhores, boa tarde.

      Pesquisei muito antes de abrir esse post, inclusive aqui, neste fórum. Encontrei dúvidas parecidas as quais tentei adaptar ao meu caso porem sem sucesso.

      A questão é a seguinte:

      Foi desenvolvida uma API em ASP.NET Core 2.0, mas por algumas solicitações do cliente, necessitei migrar para a versão 3.1. Existe uma SPA em Angular 7 que faz a requisição à API através de um método POST passando os parâmetros para a API que retornava um conjunto de dados para aplicação montar a tela. Após a atualização parou de funcionar! Por isso, gostaria de pedir a ajuda de vocês, por que, eu já esgotei as minhas tentativas.

      **No Controller da API está da seguinte maneira:**
       
      1 2 3 4 5 6 7 8 [HttpPost] [Route("api/[controller]")] public IGResult Post(Filtro filtro) {     Console.WriteLine("filtro: " + filtro);     var app = new IgApplication();     return app.getInstrucoes(filtro); }
      **E no angular se encontra dessa forma:**
       
      1 return this._http.post<IgResult>(environment.url + 'api/IG',  this.Filtro, options)

      Ao debugar a API, percebo que os dados do parâmetro **body** chegam nulos. Já tentei das seguintes maneiras abaixo, mudar a implementação do POST na API porém sem sucesso:
       
      1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 > //public async Task<IActionResult> Post([FromBody] Filtro pessoa) >         //public HttpResponseMessage Post(Filtro pessoa) >         //public async Task<ActionResult<IList<Todo>>> Create([FromBody]TodoCreateViewModel model) >         //public Task<IActionResult> Post([FromBody] Filtro filtro) >         //public ActionResult<Filtro> Post([FromBody] Filtro filtro) >         //public HttpResponseMessage Post(Filtro filtro) >         //public string Post([FromBody] Filtro filtro) >         //public IActionResult Post([FromBody] Filtro filtro) >         //{ >         //var app = new IgApplication(); >         //return app.getInstrucoes(filtro); >         //return null;// Json(filtro); >         //} >         //public async System.Threading.Tasks.Task<string> Post(HttpRequestMessage request) >         //{ >         //    string body = await request.Content.ReadAsStringAsync(); >         //    return body; >         //}

      Por isso se possível, gostaria muito de contar com a colaboração de vocês.

      Desde já muito obrigado!
    • By rdavisp
      Senhores, bom dia.
      Mais uma vez recorro a ajuda de vocês para algo que não domino ainda. Vamos lá!
      Tenho uma API que quando startada, ela sobe no seguinte endereço: http://localhost:49013/api/values. Percebi que isto é parametrizado no arquivo launchSettings.json, que está assim:
       
      {   "iisSettings": {     "windowsAuthentication": false,     "anonymousAuthentication": true,     "iisExpress": {       "applicationUrl": "http://localhost:49013/",       "sslPort": 0     }   },   "profiles":    {     "IIS Express": {       "commandName": "IISExpress",       "launchBrowser": true,       "launchUrl": "api/values",       "environmentVariables": {         "ASPNETCORE_ENVIRONMENT": "Development"       }     },     "Cliente.IG.WebAPI": {       "commandName": "Project",       "launchBrowser": true,       "launchUrl": "api/values",       "environmentVariables": {         "ASPNETCORE_ENVIRONMENT": "Development"       },       "applicationUrl": "http://localhost:49012/"     }   } }  
      No meu controller da API, tenho seguinte método dentro do namespace:
       
          [Produces("application/json")]     [Route("api/IG")]     [ApiController]     public class IGController : Controller     {         [HttpPost]         public IGResult Post([FromBody] Filtro filtro)         {             var app = new IgApplication();             return app.getInstrucoes(filtro);         }     }  
      O "IgApplication" cria uma instância da classe onde é gerado uma lista que é populada com os valores atribuídos do DAO.
       
      Quando inicializo a aplicação "A" em angular através do localhost (http://localhost:4200/). Dentro do meu arquivo environment.prod.ts tenho a chamada:
       
      export const environment = {   production: true,   url: 'http://localhost:49013/' };  
      Ela passa por esse controller e segue o fluxo e faz o que tem que ser feito. 
      Porém, eis a questão! Eu possuo a aplicação "B", que acessa a mesma API porém possui funcionalidades diferente, por isso, dentro do mesmo controller eu criei uma nova classe e um método:
       
          [Produces("application/json")]     [Route("api/Item")]     public class APIIgItemController : Controller     {         [HttpGet]         public ItensResult Post([FromBody] Itens ValorItem)         {             var app = new CRUDApplication();             return app.GetItens();         }     }  
      Como faço para quando for startar a aplicação "B", ele passe por esse método "ItensResult" ao invés "IGResult", sendo que ambas são executadas pelo localhost:4200? Ou isso eu defino na aplicação angular? Vi que é possível configurar mais de uma "applicationUrl" dentro do json. Devo considerar essa configuração?
       
      Grato a quem puder ajudar!
       
    • By Good
      Boa noite,
       
      para um sistema que é muito acessado uma página básica, mas que sempre faz conexão com banco de dados apenas para ler uma informação que já é fixada, é muito raro ter uma atualização.
       
      Então, pensando em economizar e acelerar o site, pensei nestas maneiras:
       
      1. Já uso cloudflare, e ele guarda no cachê algumas informações. Pensei em gravar as informações em TXT, e sempre usar um file_get_contents (através de uma url) para ler as informações. Será que essas informações entrarão em cachê no cloudflare e poupará mais do servidor?
      2. Então usar apenas cloudflare e puxar a informação de forma local.
      3. Manter a conexão com banco de dados a cada acesso de um usuário
       
       
      Qual das 3 opções seria mais viável para milhares de conexões diárias?
    • By jurandyneto
      Pessoal alguém pode me ajudar?
       
      A nota da prova final tá saindo errado
      #include <stdio.h> #include <stdlib.h> int main(void) { float primeiraNota, segundaNota, terceiraNota; float media, notaDaProvaFinal; printf("\n\t\tCalculo da Nota Final.\n\n"); primeiraNota = -1; while ((primeiraNota < 0) || (primeiraNota > 10)) { printf(" Primeira Nota.: "); scanf("%f", &primeiraNota); } segundaNota = -1; while ((segundaNota < 0) || (segundaNota > 10)) { printf(" Segunda Nota..: "); scanf("%f", &segundaNota); } terceiraNota = -1; while ((terceiraNota < 0) || (terceiraNota > 10)) { printf(" Terceira Nota.: "); scanf("%f", &terceiraNota); } media = (primeiraNota + segundaNota + terceiraNota) / 3; printf("\n\n\tMedia: %.2f\n\n", media); if (media >= 7) printf("\tAPROVADO!\n\n"); if(media >= 3 && media <= 6.9){ printf("\tREPROVADO - COM DIREITO A PROVA FINAL!\n"); notaDaProvaFinal = (media * 7) - 50 /3; printf("\tNota minima a ser tirada na prova final: %.1f\n\n", notaDaProvaFinal); } if (media < 4) printf("\tREPROVADO - SEM DIREITO A PROVA FINAL!\n\n"); system("pause"); return 0; }  
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.