Jump to content
rtavix

Validar quantidade de carácter de um determinado campo de uma tabela. (Dúvidas)

Recommended Posts

Tenho uma planilha com certos dados, e nessa planilha tenho a coluna M chamada NUCEP, eu preciso validar a quantidade de carácter antes de realizar minha importação, alguém poderia me sugerir uma forma de como fazer isso?

Share this post


Link to post
Share on other sites
1 hora atrás, quintelab disse:

Opa Quintelab, então brother, eu tenho esse código:

 

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

            bool importado = false;

            

            foreach (var linha in dados)
            {
                i++;
                //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 " + (linha["indice"]) + " deve ser preenchida. <br>");
                    arquivoInvalidado = true;
                }

                if (!importado)
                {
                    //Validação de campos obrigatórios
                    if (linha.ItemArray[0].ToString().Equals(""))
                    {
                        log.Append("A célula A linha " + (linha["indice"]) + " deve ser preenchida. <br>");
                        arquivoInvalidado = true;
                    }
                    if (linha.ItemArray[6].ToString().Equals(""))
                    {
                        log.Append("A célula G linha " + (linha["indice"]) + " deve ser preenchida. <br>");
                        arquivoInvalidado = true;
                    }
                    if (linha.ItemArray[7].ToString().Equals(""))
                    {
                        log.Append("A célula H linha " + (linha["indice"]) + " deve ser preenchida. <br>");
                        arquivoInvalidado = true;
                    }
                    if (linha.ItemArray[14].ToString().Equals(""))
                    {
                        log.Append("A célula O linha " + (linha["indice"]) + " 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 linha " + (linha["indice"]) + " e / ou célula C referente a linha " + (linha["indice"]) + " devem estar preenchidas. <br>");
                        arquivoInvalidado = true;
                    }

                    //Valida se campo DataSep e Data de recebimento na oriegem encontram- se preenchidos
                    if (linha.ItemArray[18].ToString().Equals(""))
                    {
                        log.Append("A célula S linha " + (linha["indice"]) + " deve ser preenchida. <br>");
                        arquivoInvalidado = true;
                    }
                    if (linha.ItemArray[19].ToString().Equals(""))
                    {
                        log.Append("A célula T linha " + (linha["indice"]) + " deve ser preenchida. <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 " + (linha["indice"]) + " deve ser preenchida. <br>");
                        arquivoInvalidado = true;
                    }
                    if (linha.ItemArray[5].ToString().Equals(""))
                    {
                        log.Append("A célula F referente a linha " + (linha["indice"]) + " 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 " + (linha["indice"]) + ". 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 " + (linha["indice"]) + " não corresponde a vara e comarca informada. Favor corrigir o sistema ou a planilha. <br>");
                                arquivoInvalidado = true;
                            }
                        }
                    }

                    if (listaInteressadoArq.Count != 0)
                    {
                        if (!listaInteressadoArq.Exists(o => o.Nome.Equals(linha.ItemArray[6].ToString().ToUpper())))
                            listaInteressadoArq.Add(this.setInteressado(linha, i));
                        else //apenas para verificar os dados do interessado informados na planilha
                            setInteressado(linha, i);
                    }
                    else
                        listaInteressadoArq.Add(this.setInteressado(linha, i));

                    //setInteressado(linha, i);
                }
            }

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

Nesse código acima, eu gostaria de aplicar essa função de validar total de caracteres digitado em cada linha referente a este campo (coluna) da planilha excel e a ideia é já que possuo uma maneira de pegar o indice da linha, pegar e criar um log e enviar para o usuário, informando o nome da cédula e linha e a quantidade de caracter. É meio doido isso, mas a usuário me solicitou isso.

 

Nesse outro código eu tenho o método onde eu verifico o layout da planilha excel.

 

private bool VerificaLayout(DataTable dt)
        {
            if (!dt.Rows[4].ItemArray[0].Equals("Data de Requisição do Pgto"))
                return false;
            if (!dt.Rows[4].ItemArray[1].Equals("NUMERO PROCESSO ANTERIOR"))
                return false;
            if (!dt.Rows[4].ItemArray[2].Equals("NUMERO JUDICIAL"))
                return false;
            if (!dt.Rows[4].ItemArray[3].Equals("COMARCA"))
                return false;
            if (!dt.Rows[4].ItemArray[4].Equals("VARA"))
                return false;
            if (!dt.Rows[4].ItemArray[5].Equals("VARANOME"))
                return false;
            if (!dt.Rows[4].ItemArray[6].Equals("NOME"))
                return false;
            if (!dt.Rows[4].ItemArray[7].Equals("CPF"))
                return false;
            if (!dt.Rows[4].ItemArray[8].Equals("DEENDERECO"))

                return false;
            if (!dt.Rows[4].ItemArray[9].Equals("NUENDERECO"))
                return false;
            if (!dt.Rows[4].ItemArray[10].Equals("DECOMPLEMENTO"))
                return false;
            if (!dt.Rows[4].ItemArray[11].Equals("DEBAIRRO"))
                return false;
            if (!dt.Rows[4].ItemArray[12].Equals("NUCEP"))
                return false;
            if (!dt.Rows[4].ItemArray[13].Equals("NMMUNICIPIO"))
                return false;
            if (!dt.Rows[4].ItemArray[14].Equals("BRUTO"))
                return false;
            if (!dt.Rows[4].ItemArray[15].Equals("IRPF"))
                return false;
            if (!dt.Rows[4].ItemArray[16].Equals("LIQUIDO"))
                return false;
            if (!dt.Rows[4].ItemArray[17].Equals("Nº SEP"))
                return false;
            if (!dt.Rows[4].ItemArray[18].Equals("DATA SEP"))
                return false;
            if (!dt.Rows[4].ItemArray[19].Equals("DATA DE RECEBIMENTO NA ORIGEM"))
                return false;

            return true;
        }

 

Você teria alguma ideia do que eu poderia esta fazendo? Irei olhar teu tópico e avaliar, mas aceito sugestões amigo. valeu até o momento.

Share this post


Link to post
Share on other sites
Em 30/05/2018 at 18:23, rtavix disse:

    if (linha.ItemArray[0].Length > 5)

cara nao conheço essa linguagem mais deve ser assim talvez

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 fernandoxwiggy
      Bom dia,
      Alguém já teve que desenvolver o CIOT da empresa E-frete em C#?
       
      Estou buscando exemplos de como fazer usando o web service deles (http://dev.efrete.com.br/Services/LogonService.asmx).
      Eu acredito que preciso chamar o "login" (depois o logout) dentro desse web service, mas ele é uma interface e não estou achando um exemplo de chamar um procedimento em um web service que seja um interface.
       
      Agradeço desde já se alguém puder ajudar.
    • By User386_Denilson
      e aí pessoal, blz?
       
      Vou colocar aqui minha duvida...
      Tenho um projeto em net Core 2.2, usadon mongodb. Tenho uma collection antiga (Pessoas) que o pessoal foi alimentado com muita coisa, e agora estou organizando em pessoa fisica e pessoa juridica.
      Eu faço a busca usando o filtro por id:
      public async Task<PessoaDadosCad> GetPessoaFisica(string id) { var pessoa = await passaiMongoCollection.FindAsync(pessoa => pessoa.Id == id); var data = JsonConvert.SerializeObject(await pessoa.FirstOrDefaultAsync()); PessoaDadosCad simplifiedPerson = JsonConvert.DeserializeObject<PessoaDadosCad>(data.ToString()); return simplifiedPerson; }  
      (pessoa => pessoa.Id == id) ao executar esse comando de busca, a classe vinculada é Pessoa.
      Eu queria ver com vcs se tem como não vincular uma classe no momento da busca??
      Obrigado
    • 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!
       
×

Important Information

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