Jump to content
rtavix

Retornando mensagem para o usuário- Dúvidas

Recommended Posts

 Tenho o seguinte problema, minha célula de data na planilha de excel é um campo obrigatório, no entanto, deixando não preenchido teria que retornar uma mensagem com o log para o usuário, no entanto, não retornou nenhuma mensagem de log informando que a linha S da célula 1 deve ser preenchido com uma data, mas não aparece. Alguém poderia me ajudar, por favor?

 

Segue meu código abaixo:

 

private void  setProcInter (processo processado, interessados interessados, linha DataRow)   
        {  
            int  i = 0;  
experimentar  
                {  
                    DateTime DateSep = DateTime.Parse (line.ItemArray [18] .ToString ());  
                    processInterested.DateSep = DateSep;  
                }  
                pegar  
                {  
                    i = i + 1;  
                    logErro.Append ( "A célula S"  + (i) +  "deve ser completada com uma data. <br> <br>" );  
                    fileInvalidated =  true ;  
                }  
  
}  
  
  
 Privado void  PreliminaryVerification (dados IEnumerable <DataRow>)   
        {  
            int  i = 0;  
  
            bool  importado =  falso ;  
            foreach (var line  in  data)  
            {  
                i = i + 1;  
                // Verifica que nenhuma planilha com o numSEP inserido não tenha   
               // já foi importado                  
                if  (! line.ItemArray [17] .ToString (). Igual a ( "" ))  
                {  
                    if  (aplProcessinterested.listProcInterPorCodSep ( decimal .Parse (line.ItemArray [17] .ToString ())). Contagem! = 0)  
                    {  
                        importado =  true ;  
                        pausa ;  
                    }  
                }  
                outro  
                {  
                    log.Append ( "A célula S para a linha"  + (i) +  "deve ser concluída. <br>" );  
                    fileInvalidated =  true ;  
                }  
}  

 

Share this post


Link to post
Share on other sites

Olá, não traduza o código. Acaba traduzindo mais do que o necessário e acaba prejudicando no entendimento do código.

Share this post


Link to post
Share on other sites
21 minutos atrás, Gabriel Heming disse:

Olá, não traduza o código. Acaba traduzindo mais do que o necessário e acaba prejudicando no entendimento do código.

Oi Gabriel, me desculpa brother. Olha estou com problemas ao exibir o log para o usuário, tipo, na minha planilha existe a coluna Data Sep, que é campo obrigatório, entretanto, quando eu compilo a aplicação ele salva a planilha no banco com o campo nulo, isso não deveria acontecer, deveria disparar o log informando que deverá ser preenchida, só está faltando isso para finalizar. poderia por gentileza me ajudar cara? Segue meu código atualizado.

 private void setProcInter(Processo processo, Interessado interessado, DataRow linha)
        {
            int i = 0;

				try
                {
                    DateTime DataSep = DateTime.Parse(linha.ItemArray[18].ToString());
                    processoInteressado.DataSep = DataSep;
                }
                catch
                {
                    i = i + 1;
                    logErro.Append("A célula S" + (i) + " deve estar preenchida com uma data. <br>");
                    arquivoInvalidado = true;
                }
 					aplProcessoInteressado.salvar(processoInteressado);
}

 

Share this post


Link to post
Share on other sites

Você deve tratar isso. Seu catch até faz o log, mas não impede o fluxo de processamento e o salvar é executado.

 

Infelizmente, não sei como o seu sistema está tratando exceções nas camadas superiores. O que eu faria é lançar novamente a mesma exception para interromper a execução.

catch
{
    i = i + 1;
    logErro.Append("A célula S" + (i) + " deve estar preenchida com uma data. <br>");
    arquivoInvalidado = true;
  
    throw; //irá lançar a mesma exception para a camada superior
}

aplProcessoInteressado.salvar(processoInteressado);

Entretanto, isso deve ser de acordo com o que seu sistema está tratando ou não.

Share this post


Link to post
Share on other sites

Somente aparece esse outro log, log da Data não aparece.

Log de Importação:
 

No sistema não existe vara de execução associada a comarca informada na linha 371. Favor corrigir o sistema. 

Edited by Gabriel Heming
remover o quote

Share this post


Link to post
Share on other sites

Se não cai no catch, meu código não irá fazer nada mesmo.

 

Vamos tentar uma abordagem diferente, pois, DateTime.Parse deveria lançar uma exception. Utilize TryParse no lugar, que retornará true/false no processo (e é mais rápido em execução).

DateTime DataSep;

if (DateTime.TryParse(linha.ItemArray[18].ToString() , out DataSep))  {
    processoInteressado.DataSep = DataSep;
  
    //Apenas para ter certeza da execução do código.
    logErro.Append("Adicionou a data corretamente");
}
else
{
    i = i + 1;
    logErro.Append("A célula S" + (i) + " deve estar preenchida com uma data. <br>");
    arquivoInvalidado = true;
}

 

Share this post


Link to post
Share on other sites
32 minutos atrás, Gabriel Heming disse:

Se não cai no catch, meu código não irá fazer nada mesmo.

 

Vamos tentar uma abordagem diferente, pois, DateTime.Parse deveria lançar uma exception. Utilize TryParse no lugar, que retornará true/false no processo (e é mais rápido em execução).


DateTime DataSep;

if (DateTime.TryParse(linha.ItemArray[18].ToString() , out DataSep))  {
    processoInteressado.DataSep = DataSep;
  
    //Apenas para ter certeza da execução do código.
    logErro.Append("Adicionou a data corretamente");
}
else
{
    i = i + 1;
    logErro.Append("A célula S" + (i) + " deve estar preenchida com uma data. <br>");
    arquivoInvalidado = true;
}

 

Oi amigo, eu adicionei novamente seu código, coloquei o breakpoint ao tentar compilar, ele não passa no if de jeito nenhum, eu não sei se não está dentro das chaves corretamente, resolvi print meu código pra você ver como está, não retorna ainda o log informando para preencher a data, tenso isso :9

aplicação.jpg

Share this post


Link to post
Share on other sites

Se nem o breakpoint foi pego, há alguma coisa nesse código. Eu consigo imaginar as situações abaixo:

  • O método setProcInter não está sendo executado;
  • Algum código, antes do código em questão, está lançando alguma exception que está sendo tratada em outro lugar;
  • O código que você está executando não é o mesmo que você está fazendo deploy (não é o código atualizado).

Faça o debug de toda a execução e veja o que está ocorrendo.

Share this post


Link to post
Share on other sites

Eu vou procurar compilar novamente e vê o que estou fazendo de errado. Mas até o momento, te agradeço pelas sugestões, que são bem valiosas e guardarei de aprendizagem no dia- a- dia! 

Edited by Gabriel Heming
remover o quote

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.