Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

rtavix

Problema para lê o próximo arquivo

Recommended Posts

Pessoal, boa tarde!

 

Estou com problemas para lê os arquivos de um diretório, apresenta erro como se estivesse passando o caminho errado, porém não enxergo essa falha, alguém poderia me orientar?

Aqui é aonde eu verifico a extensão do arquivo e informo o caminho:

 

Método para mover o arquivo:

Método de inserir o log:

 

Erro:

System.IO.FileNotFoundException: 'Não foi possível localizar o arquivo 'D:\Pendrive\PENDENTES\CGc0001.cpv\CGc0360.cpv'.'

Isso acontece que toda vez vou ler o próximo arquivo.

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 14/08/2018 at 08:20, quintelab disse:

Repara no caminho que esta no erro. Imagino que o correto é D:\Pendrive\PENDENTES\CGc0001.cpv e você esta passando D:\Pendrive\PENDENTES\CGc0001.cpv\CGc0360.cpv

Quintelab, alterando o código dessa forma, eu consigo mover o arquivo:

Ao compilar e varrer linha por linha, identifiquei que o problema encontrava- se nesse método:

 

Porque eu passo o nome de um desses arquivos, como eu poderia melhorar o código, que ao invés de passar o nome do arquivo para mover ele, eu pego pela extensão do arquivo, que se chama .cpv, como poderia estar fazendo? Tem alguma ideia?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Aqui tem um pequeno exemplo:

private void mover()
    {
      DirectoryInfo dir = new DirectoryInfo(@"C:\retorno");
      string destino = @"C:\entrada\";

      foreach (FileInfo f in dir.GetFiles("*.txt"))
      {
        File.Move(f.FullName, destino + f.Name );
      }
    }

Pega todos os arquivos com extensão txt da pasta retorno e joga na pasta destino.

Compartilhar este post


Link para o post
Compartilhar em outros sites
13 horas atrás, quintelab disse:

Aqui tem um pequeno exemplo:


private void mover()
    {
      DirectoryInfo dir = new DirectoryInfo(@"C:\retorno");
      string destino = @"C:\entrada\";

      foreach (FileInfo f in dir.GetFiles("*.txt"))
      {
        File.Move(f.FullName, destino + f.Name );
      }
    }

Pega todos os arquivos com extensão txt da pasta retorno e joga na pasta destino.

Implementei sua sugestão quintelab, mas ao depurar ele informa que não foi possivel encontrar o arquivo x . cpv, e ao verificar ele move até os arquivos que não podem ser movidos. 

 

Se eu tenho um comprovante com o código de barras e ao verificar no banco se ele existe na tabela proc_inter, ele me retorna que não existe, então não pode ser inserido. Já os demais que existem no banco, ai ele insere, registra o log, e como um determinado código de barras não existe lá no banco, eu pego esse arquivo e deixo ele na pasta pendente ainda, até que os responsáveis verificam por qual motivo ele não foi cadastrado nessa tabela. Resumidamente é isso, porém ao usar sua sugestão amigo ele retorna essa mensagem :/

Compartilhar este post


Link para o post
Compartilhar em outros sites

Quintelab, uma dúvida, se meu arquivo .cpv que possui um determinado código de barras não existir na tabela sdpj_proc_inter no banco de dados, eu retorno um log informando esse ocorrido, mas eu iria precisar de mover esse arquivo para uma pasta processados com pendnecia, como eu poderia fazer essa condição? Esse método aqui:

Serve para mover arquivos .cpv que possuem os códigos de barras cadastrados na tabela sdpj_proc_Inter, mas como eu poderia está fazendo para a condição exposta logo acima? 

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 30/08/2018 at 05:20, quintelab disse:

Primeira pergunta é: cp,p vpce sabe se um arquivo possue códigos de barras cadastrados na tabela sdpj_proc_Inter ?

cada arquivo possui a extensão cpv. Esse arquivo é gerado pelo banco, porém existe determinados arquivos que vem com um código de barras que não existe nessa tabela do banco, eu sei disso porque eu fiz a lógica que verifica se existe ou não, no caso seria essa parte do código que eu faço isso:

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 30/08/2018 at 05:20, quintelab disse:

Primeira pergunta é: cp,p vpce sabe se um arquivo possue códigos de barras cadastrados na tabela sdpj_proc_Inter ?

Aqui é aonde verifico se possui o código de barras na tabela do banco:

Desculpa por esta postando em partes, mas para não ficar uma coisa "bagunçada" Quintelab, aguardo teu retorno. Valeu até o momento amigo!

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por mr22robot
      Ola caros amigos. 
      Estou com uma dúvida aqui que embora nao tenho achado ainda uma resposta, acredito que haja.
      Estou estudando a tão sonhada linguagem de programação asp.net core mvc. Linguagem essa que demorei 5 anos pra iniciar os estudos rsrs.
      Mas estou agarrado em uma situação. 
      Estou usando como base de dados nos meus estudos um banco Oracle. Que já tem algumas informações nele. Utilizei o SCAFFOLD para criar as classes e o contexto baseado no banco e tabelas existentes. 
      Porem agora na fase das consultas, estou perdido em como utilizar o IN que eu utilizo no oracle; no LINQ.
      Ex: 
      SELECT CODPROD,DESCRICAO FROM PRODUTO WHERE CODPROD IN(1,2,3,4,5,6) Como eu utilizo esse filtro com uma restrição de códigos de produtos? no caso o where codprod in(1,2,3,4,5,6) ?.
      Desde já obrigado pela ajuda.
    • Por luis0101010
      1.      Programe uma função que recebe um número inteiro e verifica se todos os dígitos deste número são iguais ou diferente e liste eles em ordens crescentes.
      Obs: Código fonte com no mínimo de 10 dígitos.
       
      Como exemplo, os números 456, −235, e 5 satisfazem esta condição, enquanto que o número 6 não.
       
      2.      Crie também a função main que recebe o valor do número digitado pelo usuário e exibe na tela uma mensagem informando se os dígitos deste número são iguais.
       
      Exemplo:
      --Exemplo 1:
      Informe um número:
      -555
      Numero informado possui todos os dígitos iguais
      --Exemplo 2:
      Informe um número:
      67
      Número informado não possui todos os dígitos iguais
    • Por Rafael Massula
      Boa noite pessoal, 
      Tenho o seguinte código em .Net que faz a comparação de uma senha que foi criptografada e salva no banco com a senha comum que o usuário conhece. O algoritmo que desenvolvi foi esse da image.png porem preciso converter essa verificação para JavaScript pela seguinte necessidade, será uma aplicação em electron e ela poderá funcionar offline então não terei como mandar a verificação para o servidor. Existe alguma possibilidade? Desde já agradeço. 

    • Por TheLord23
      ESTOU COMEÇANDO AGORA NA PROGRAMAÇÃO COM VISUALG E TERIA QUE COLOCAR ESTE CODIGO EM UM LAÇO DE REPETIÇÃO.
      POREM NÃO ESTOU CONSEGUINDO PODERIAM ME AJUDAR ?
       
      SÓ PENSANDO QUE O USUÁRIO IRA DIGITAR O TAMANHO DO VETOR, APOS ISSO CADA OPÇÃO QUE ELE ESCOLHER E ELA SER EXECUTADA DE FORMA CORRETA ELE VOLTARA PARA O MEUNU PRINCIPAL DAS OPÇÕES ATE QUE ELE SELECIONE A OPÇÃO "F"
       
      POREM TENTEI ESCREVELO USANDO ENQUANTO MAS ACABOU QUE EU NÃO CONSIGO PREVINIR OS ERROS DO USUÁRIO QUANDO ELE COLOCA AS INFORMAÇÕES
       
      TIPO:
      -ARMAZENAR UM NÚMERO NO VETOR E ESSE NÚMERO NÃO SER SOBRESCREVIDO ATE QUE O PROGRAMA SEJA ENCERRADO
      -SE ELE DIGITAR PRA BUSCAR OU INSERIR O NÚMERO ZERO O PROGRAMA INFORMAR QUE O VALOR É INVÁLIDO
       
      TENTEI USAR PROCEDIMENTOS E FUNÇÕES MAS OS ERROS CONTINUARAM.
       
       
       
      Algoritmo "DESAFIO"
      Var
         AUX,CONTADOR,BUSCAR:INTEIRO
         POSICAO,AUX_TEMP:INTEIRO
         OPCAO:CARACTERE
         RESULT_BUSCA: LOGICO
         SOMA_VET:REAL
         NUMERO:VETOR[1..500]DE INTEIRO
      Inicio
         ESCREVAL("*********************************")
         ESCREVAL("* CADASTRO DE VETORES - DESAFIO *")
         ESCREVAL("*********************************")
         ESCREVA("DIGITE O TAMANHO DO VETOR A SER CADASTRADO: ")
         LEIA(AUX)
         NUMERO[AUX] <- AUX
         ESCREVAL("A - Cadastrar um novo número;")
         ESCREVAL("B - Buscar um número")
         ESCREVAL("C - Excluir um número;")
         ESCREVAL("D - Listar os números cadastrados;")
         ESCREVAL("E - Exibir a soma dos números do vetor;")
         ESCREVAL("F - Sair do sistema.")
         LEIA(OPCAO)
         OPCAO <- MAIUSC(OPCAO)
         ESCOLHA OPCAO
         CASO "A"
            PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
               ESCREVA("DIGITE O VALOR QUE SERÁ ARMAZENADO NA",CONTADOR,"ª POSIÇÃO DO VETOR: ")
               LEIA(NUMERO[CONTADOR])
            FIMPARA
         CASO "B"
            ESCREVA("QUAL NÚMERO DESEJA ENCONTRAR: ")
            LEIA(BUSCAR)
            PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
               SE NUMERO[CONTADOR] = BUSCAR ENTAO
                  RESULT_BUSCA <- VERDADEIRO
                  POSICAO <- CONTADOR
               FIMSE
            FIMPARA
            PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
               ESCREVAL(NUMERO[CONTADOR])
            FIMPARA
            ESCREVAL("")
            ESCREVAL("---------")
            SE RESULT_BUSCA = VERDADEIRO ENTAO
               ESCREVAL("O NÚMERO",BUSCAR,"FOI ENCONTRADO E ESTA NA POSIÇÃO",POSICAO)
            SENAO
               ESCREVAL("O NÚMERO NÃO FOI ENCONTRADO !")
            FIMSE
         CASO "C"
            escreval("QUAL NÚMERO DESEJA EXCLUIR DO VETOR: ")
            leia(BUSCAR)
            SE NUMERO[CONTADOR] = BUSCAR ENTAO
               NUMERO[CONTADOR] <- 0
               ESCREVAL("O NÚMERO",BUSCAR,"NA POSIÇÃO",POSICAO,"DO VETOR FOI EXCLUIDO !")
            FIMSE
            PARA CONTADOR DE 1 ATE NUMERO[AUX]
               PARA AUX DE CONTADOR + 1 ATE AUX FACA
                  SE NUMERO[AUX] > NUMERO[CONTADOR]
                     AUX_TEMP <- NUMERO[AUX]
                     NUMERO[AUX] <- NUMERO[CONTADOR]
                     NUMERO[CONTADOR] <- AUX_TEMP
                  FIMPARA
               FIMPARA
               ESCREVA("VALROES DO VETOR: ")
               PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
                  ESCREVAL(NUMERO[CONTADOR])
               FIMPARA
            CASO "D"
               ESCREVA("VALORES DO VETOR: ")
               PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
                  ESCREVAL(NUMERO[CONTADOR])
               FIMPARA
            CASO "E"
               PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
                  SOMA_VET <- SOMA_VET + NUMERO[CONTADOR]]
               FIMPARA
               ESCREVAL("")
               ESCREVA("A SOMA DO VETOR É:",SOMA_VET)
               
            CASO "F"
               ESCREVAL("ENCERRANDO SISTEMA...")
            OUTROCASO
               ESCREVAL("OPÇÃO INVÁLIDA !")
            FIMESCOLHA
      Fimalgoritmo
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.