Jump to content
rtavix

Ler arquivo e inserir no banco

Recommended Posts

Preciso ler um arquivo e salvar o campo de Data de agendamento, valor do Documento, protocolo, código de barras, Registro: gravar data e hora, como poderia está fazendo? Segue meu código em anexo. O arquivo pode ser aberto no txt, porém não consigo anexar. Dentro desse arquivo eu possuo diversos comprovantes, deixei somente dois como base na explicação. Preciso de ajuda por gentileza. 

using System;
using System.Collections;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;


namespace ServicoProcessamentoComprovantes
{
    public class ProcessaRetorno
    {
        private static object objReader;

        private static void Main(string[]args)
        {
            List<string> valoresEncontrados = new List<string>();

            try
            {
                string[] Arquivo = System.IO.Directory.GetFiles(@"\\S3A601\ftp@sefarix\forem\Saida_SDPJ\teste", "*.cpv");

                foreach(var item in Arquivo)
                {
                    string[] linha = item.Split(new[] { ' ' }, StringSplitOptions.RemoveEmptyEntries);

                    if(linha.Length >=3)
                    {
                        valoresEncontrados.Add(linha[2]);
                    }
                }
            }
            catch(Exception ex)
            {

            }
        }
    }
}

Dados do arquivo:

 

------------------------------------------------

CONTAK TECNOLOGIA SA

--------------CONTAK CORPORATIVO--------------

    Pagamentos e Transferencias Eletronicas

 

PAGAMENTO: DEPOSITO JUDICIAL               

------------------------------------------------

Cliente:        José Frederico Costa e Silva               

                Enc Ger APLIX - Cta C          

Conta:          5.535.0125

Agencia:        104-Central                       

 

Cod. Barras:    898800000078  000002130424

                017092700009  270400028680

Conveniada:     DEPOSITO JUDICIAL               

 

Dt.Agendamento: 29/09/2017

Vlr.Documento:  R$500,00

Protocolo:      94651134

 

Origem:         CONTAK CORPORATIVO

================================================

             TRANSACAO EFETIVADA 

================================================

Registro: 29/09/2017 11:21:29  /local/home/tef/d/20170929/sfcg012.

Emissao.: 30/09/2017 09:54:19 

------------------------------------------------

CONTAK TECNOLOGIA SA

--------------CONTAK CORPORATIVO--------------

    Pagamentos e Transferencias Eletronicas

 

PAGAMENTO: DEPOSITO JUDICIAL               

------------------------------------------------

Cliente:        José Frederico Costa e Silva                

                Enc Ger APLIX- Cta C          

Conta:          5.535.018

Agencia:        104-Central                       

 

Cod. Barras:    898300000032  500002140426

                017092700009  577000029380

Conveniada:     DEPOSITO JUDICIAL               

 

Dt.Agendamento: 29/09/2017

Vlr.Documento:  R$350,00

Protocolo:      94651136

 

Origem:         CONTAK CORPORATIVO

================================================

             TRANSACAO EFETIVADA 

================================================

Registro: 29/09/2017 11:21:29  /local/home/tef/d/20170929/sfcg012.

Emissao.: 30/09/2017 09:54:19 

Edited by rtavix
Alterar informação

Share this post


Link to post
Share on other sites

Se o arquivo for normalizado, com campos bem definidos você pode mapear isso tudo numa classe. O negócio é que você precisa identificar as linhas e assim setar as propriedades.

 

Digamos que você possui uma classe Comprovante:

class Comprovante
{
	public DateTime DataAgendamento{get;set;}
  	public Decimal ValorDocumento{get;set;}
  	public String Protocolo{get;set;}
  	public String CodigoBarras{get;set;}
  	public DateTime DataRegistro{get;set;}
}

Seria necessário ler o arquivo linha a linha e ir identificando e criando os objetos da classe Comprovante. Para isso também seria necessário alguma forma de identificar o fim de um comprovante, se houver mais de um por arquivo.

 

using(FileStream fs = new FileStream("arquivo.cpv", FileMode.Open)) 
{
 using(StreamReader sr = new StreamReader(fs)) 
 {
  var linha = "";
  var fimDoComprovante = "@FIM@"; // alguma forma de identificar o fim do comprovante
  var comprovanteLista = new List < Comprovante > ();
  var comprovante = new Comprovante();
  while ((linha = sr.ReadLine()) != null) 
  {
   if (linha.StartsWith("Cod. Barras")) 
   {
    comprovante.CodigoBarras = linha.Split(':')[1];
   }

   if (linha.Contains("@FIM@")) 
   {
    comprovanteLista.Add(comprovante);
    comprovante = new Comprovante();
   }
  }
 }
}

Use apenas como uma ideia de como fazer, não faça tão sujo assim! :p

Share this post


Link to post
Share on other sites
10 horas atrás, Kelvin Dules disse:

Se o arquivo for normalizado, com campos bem definidos você pode mapear isso tudo numa classe. O negócio é que você precisa identificar as linhas e assim setar as propriedades.

 

Digamos que você possui uma classe Comprovante:


class Comprovante
{
	public DateTime DataAgendamento{get;set;}
  	public Decimal ValorDocumento{get;set;}
  	public String Protocolo{get;set;}
  	public String CodigoBarras{get;set;}
  	public DateTime DataRegistro{get;set;}
}

Seria necessário ler o arquivo linha a linha e ir identificando e criando os objetos da classe Comprovante. Para isso também seria necessário alguma forma de identificar o fim de um comprovante, se houver mais de um por arquivo.

 


using(FileStream fs = new FileStream("arquivo.cpv", FileMode.Open)) 
{
 using(StreamReader sr = new StreamReader(fs)) 
 {
  var linha = "";
  var fimDoComprovante = "@FIM@"; // alguma forma de identificar o fim do comprovante
  var comprovanteLista = new List < Comprovante > ();
  var comprovante = new Comprovante();
  while ((linha = sr.ReadLine()) != null) 
  {
   if (linha.StartsWith("Cod. Barras")) 
   {
    comprovante.CodigoBarras = linha.Split(':')[1];
   }

   if (linha.Contains("@FIM@")) 
   {
    comprovanteLista.Add(comprovante);
    comprovante = new Comprovante();
   }
  }
 }
}

Use apenas como uma ideia de como fazer, não faça tão sujo assim! :p

Opa Kelvin, bom dia, tentarei aplicar essas funcionalidades implementadas por você ao meu código e darei um retorno em breve, tentei anexar o arquivo, porém não é permitido anexo de arquivo de texto, somente de imagem rsrs, daí postei o arquivo no escopo mesmo da descrição. VocÊ poderia me ajudar em uma outra situação?

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 Packman1001
      Olá, senhores, estou com dificuldades em 6 questões.
      Irei mandar uma agora apenas para ver se conseguem me explicar ou criar um código e comentar linha por linha. Tenho dificuldade extrema de entender, mas não tenho vergonha de admitir. Estou correndo atrás do prejuízo e aprendendo da maneira que posso.
      Eis a questão:
      Motivação
      Flavinho acabou de chegar do supermercado com K produtos na sacola, mas perdeu o recibo da compra. Ele está tentando lembrar dos preços de cada um dos produtos e precisa da sua ajuda. Por enquanto ele consegue se lembrar das seguintes informações:
      ·         O valor total da compra foi de R reais;
      ·         Os valores dos produtos eram números inteiros distintos.
      Por exemplo, se R=12 e K=3, temos as seguintes possíveis combinações de preços para os três produtos: {1,2,9}, {1,3,8}, {1,4,7}, {1,5,6}, {2,3,7}, {2,4,6} ou {3,4,5}.
       
      Ação
      Seu programa deve computar a quantidade de possíveis combinações de preços para os K produtos.
       
      Entrada 
      A primeira linha da entrada contém dois inteiros R e K, indicando respectivamente o valor total do recibo e o número de produtos comprados.
       
      Saída
      Imprima uma linha contendo um inteiro representando a quantidade de possíveis combinações de preços para os K produtos.
       
      Restrições
      ·         1 ≤ R ≤ 100
      ·         1 ≤ K ≤ 20
       
      Exemplos

       
      >>
      12 3
      <<
      7
      >>
      10 5
      <<
      0
      >>
      10 2
      <<
      4
       
      Preciso do código que passe nesses casos de testes e que por ventura, me expliquem o que cada linha significa.
      Não tenho muito mais a dizer. Obrigado por vossas atenções, de verdade.
       
       
    • By Leon Martin
      Boa tarde pessoal, preciso de uma ajuda urgente. Vcs tem alguma ideia de como eu faço esse programa? 
       
      Enunciado:
      Na teoria dos sistemas define-se o elemento MINMAX de uma matriz como sendo o maior elemento da linha onde se encontra o menor elemento da matriz. Faça um programa que carregue uma matriz 4 x 7 com números reais, calcule e mostre seu MINMAX e sua posição (linha e coluna).
       
      Exemplo: int MAT[4][7]
      Min elemento da matriz esta na MAT[1][3] = -19 (Linha Posição 1; Coluna Posição 3)
      Max elemento da linha onde esta o min elemento da matriz esta na MAT[1][5] = 101 (Linha Posição 1; Coluna Posição 5)
       
        0
      1
      2
      3
      4
      5
      6
      0
      3
      33
      9
      2
      15
      3
      22
      1
      5
      4
      76
      -19
      93
      101
      32
      2
      3
      -1
      43
      1
      554
      21
      53
      3
      55
      34
      1231
      212
      664
      234
      13413
       
    • By guiarodrigues1
      Alguém poderia me ajudar em como colocar calculo de dilatação linear / superficial / volumétrica e de sólidos no DevC?
      Não estou conseguindo sair do lugar.
       
      Caso alguém queira mais informações segue em anexo link para baixar.
      Grato.
      Baixar PDF.
    • By Neto Dinizz
      Olá Neto Nível: InicianteMINHA CONTA Perfil Minha Assinatura Meus Cursos Favoritos Logout  Indique um amigo Mostrar menu WebAPI CRUD .NET
      11/06/2019
      1
      Entity Framework.NETASP.NET Web APIC#CRUD
      Boa noite,

      Tenho uma aplicação webapi c# utilizando entity framework CRUD, utilizando o models para montar meu json, como no models só trago os campos que vem da tabela, Tenho dúvida em como receber um parâmetro que não existe na minha tabela via parâmetro ex:

      Localhost/api/clientes?id=2&idcat=4&nome=teste

      Onde (nome) seria um parâmetro que não tenho em minha tabela, porém se existir os 2 primeiros parâmetros irei fazer um POST na tabela.

      Muito obrigado
    • By Neto Dinizz
      Bom dia,

      Poderiam me dar uma ajuda por favor,

      Estou com uma dúvida, tenho um método GET que espera o id do cliente pela url http://localhost/api/cliente/(codigo_cliente)
      estou com um problema para acessar um cliente pelo id, através de um select, gostaria de receber o id e fazer um select no banco trazendo os dados do cliente, poderiam me ajudar a incrementar o códido abaixo por favor, segue meu GET:

      // GET: api/Cliente/5
      [ResponseType(typeof(Cliente))]
      public IHttpActionResult GetCliente(int id)
      {
      Cliente cliente = db.Clientes.Find(id);
      if (cliente == null)
      {
      return NotFound();
      }

      return Ok(cliente);
×

Important Information

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