[R-br] Problemas lendo .dbf no R

Paulo Pimenta paulopimenta6 em hotmail.com
Domingo Novembro 16 04:14:46 BRST 2014


Houve um problema na última parte com o looping. Minha dificuldade no atual momento é transformar os arquivos lidos em algo do qual se acessar os dados em seu interior.

no looping há a variação de g[i] em relação ao que?

r (nome_arquivo in arquivos){
> 
> g[i] <- read.dbf(paste("I:/qgis_1/exercicio_buffer_L1/testes/teste_1/",
> nome_arquivo,sep=""))
> 
> }
Não entendi esta parte, pois para mim o comando for deveria em seu interior ter algo numérico, mas mesmo fazendo o teste:

r (i in 1:20){
> 
> g[i] <- read.dbf(paste("I:/qgis_1/exercicio_buffer_L1/testes/teste_1/nome_arquivo" ,i , ".dbf", sep=""))
> 
> }

nada dá certo.

Abraços.

Paulo Henrique de A. S. Pimenta.
Graduando em Meteorologia (Bacharelado) - IAG/USP.
Fone: +5511981318435.


> Message: 2
> Date: Thu, 13 Nov 2014 10:53:21 -0300
> From: Augusto Ribas <ribas.aca em gmail.com>
> To: r-br em listas.c3sl.ufpr.br
> Subject: Re: [R-br] Problemas lendo .dbf no R
> Message-ID:
> 	<CACMkfRxzSNWYuQcfjAExR5DA5Z8XdW1EZE+n19+YO08H+Rv1gg em mail.gmail.com>
> Content-Type: text/plain; charset="utf-8"
> 
> Opa, talvez você possa tentar o seguinte:
> 
> 
> Um exemplo, suponto que vc tenha 20 arquivos:
> 
> Quando voce da arquivos <- list.files(pattern="\\.dbf$"), você gostaria de
> ver algo como isso que fiz no vetor1 certo?
> 
> > vetor1<-paste("corte_estrada_aneis",1:20,".dbf",sep="")
> > vetor1
>  [1] "corte_estrada_aneis1.dbf"  "corte_estrada_aneis2.dbf"
>  "corte_estrada_aneis3.dbf"
>  [4] "corte_estrada_aneis4.dbf"  "corte_estrada_aneis5.dbf"
>  "corte_estrada_aneis6.dbf"
>  [7] "corte_estrada_aneis7.dbf"  "corte_estrada_aneis8.dbf"
>  "corte_estrada_aneis9.dbf"
> [10] "corte_estrada_aneis10.dbf" "corte_estrada_aneis11.dbf"
> "corte_estrada_aneis12.dbf"
> [13] "corte_estrada_aneis13.dbf" "corte_estrada_aneis14.dbf"
> "corte_estrada_aneis15.dbf"
> [16] "corte_estrada_aneis16.dbf" "corte_estrada_aneis17.dbf"
> "corte_estrada_aneis18.dbf"
> [19] "corte_estrada_aneis19.dbf" "corte_estrada_aneis20.dbf"
> 
> 
> Mas o que você ve na verdade é o que está no vetor 2, certo, porque ta tudo
> na ordem lexicografia,(Essa palavra é bonita né? Nem sei se escrevi certo,
> desculpa)
> 
> > vetor2<-sort(vetor1)
> > vetor2
>  [1] "corte_estrada_aneis10.dbf" "corte_estrada_aneis11.dbf"
> "corte_estrada_aneis12.dbf"
>  [4] "corte_estrada_aneis13.dbf" "corte_estrada_aneis14.dbf"
> "corte_estrada_aneis15.dbf"
>  [7] "corte_estrada_aneis16.dbf" "corte_estrada_aneis17.dbf"
> "corte_estrada_aneis18.dbf"
> [10] "corte_estrada_aneis19.dbf" "corte_estrada_aneis1.dbf"
>  "corte_estrada_aneis20.dbf"
> [13] "corte_estrada_aneis2.dbf"  "corte_estrada_aneis3.dbf"
>  "corte_estrada_aneis4.dbf"
> [16] "corte_estrada_aneis5.dbf"  "corte_estrada_aneis6.dbf"
>  "corte_estrada_aneis7.dbf"
> [19] "corte_estrada_aneis8.dbf"  "corte_estrada_aneis9.dbf"
> 
> Mas beleza, você ta vendo o vetor 2 na saida do arquivos <-
> list.files(pattern="\\.dbf$"), quando da arquivos.
> Uma possibilidade seria reordenar o seu arquivos, antes de fazer a leitura,
> da seguinte formula.
> 
> Crie um vetor de numeros, usando uma expressão regular para pegar somente
> os números, das string do arquivo, depois transforme em numero pro R
> entender:
> 
> 
> > numeros<-as.numeric(gsub("[a-z_.]", "\\1", vetor2))
> > numeros
>  [1] 10 11 12 13 14 15 16 17 18 19  1 20  2  3  4  5  6  7  8  9
> > vetor2
>  [1] "corte_estrada_aneis10.dbf" "corte_estrada_aneis11.dbf"
> "corte_estrada_aneis12.dbf"
>  [4] "corte_estrada_aneis13.dbf" "corte_estrada_aneis14.dbf"
> "corte_estrada_aneis15.dbf"
>  [7] "corte_estrada_aneis16.dbf" "corte_estrada_aneis17.dbf"
> "corte_estrada_aneis18.dbf"
> [10] "corte_estrada_aneis19.dbf" "corte_estrada_aneis1.dbf"
>  "corte_estrada_aneis20.dbf"
> [13] "corte_estrada_aneis2.dbf"  "corte_estrada_aneis3.dbf"
>  "corte_estrada_aneis4.dbf"
> [16] "corte_estrada_aneis5.dbf"  "corte_estrada_aneis6.dbf"
>  "corte_estrada_aneis7.dbf"
> [19] "corte_estrada_aneis8.dbf"  "corte_estrada_aneis9.dbf"
> 
> 
> Veja que a numeração ta na ordem dos arquivos, agora ordene pelos numeros
> usando order, que ele vai te dar a ordem que você quer pros indices.
> > order(numeros)
>  [1] 11 13 14 15 16 17 18 19 20  1  2  3  4  5  6  7  8  9 10 12
> > numeros[order(numeros)]
>  [1]  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17 18 19 20
> 
> 
> 
> Agora você aplica a ordem dos numeros no seu arquivos, que você pegou o ls
> do diretorio.
> > vetor2[order(numeros)]
>  [1] "corte_estrada_aneis1.dbf"  "corte_estrada_aneis2.dbf"
>  "corte_estrada_aneis3.dbf"
>  [4] "corte_estrada_aneis4.dbf"  "corte_estrada_aneis5.dbf"
>  "corte_estrada_aneis6.dbf"
>  [7] "corte_estrada_aneis7.dbf"  "corte_estrada_aneis8.dbf"
>  "corte_estrada_aneis9.dbf"
> [10] "corte_estrada_aneis10.dbf" "corte_estrada_aneis11.dbf"
> "corte_estrada_aneis12.dbf"
> [13] "corte_estrada_aneis13.dbf" "corte_estrada_aneis14.dbf"
> "corte_estrada_aneis15.dbf"
> [16] "corte_estrada_aneis16.dbf" "corte_estrada_aneis17.dbf"
> "corte_estrada_aneis18.dbf"
> [19] "corte_estrada_aneis19.dbf" "corte_estrada_aneis20.dbf"
> >
> 
> Ai você le tudo usando essa ordem
> 
> for (nome_arquivo in arquivos){
> 
> g[i] <- read.dbf(paste("I:/qgis_1/exercicio_buffer_L1/testes/teste_1/",
> nome_arquivo,sep=""))
> 
>                }
> 
> Eu acho que isso deve funcionar.
> Bem espero ter mais ajudado que atrabalhado :)
> 
> 
> 
> Em 12 de novembro de 2014 03:08, Paulo Pimenta <paulopimenta6 em hotmail.com>
> escreveu:
> 
> > Prezados,
> >
> > Estou com um problema ao ler arquivos .dbf no R. Abaixo segue a lógica que
> > usei em meu código para fazer a leitura:
> >
> >
> > ##########################################################################################
> >
> >
> >
> > ###########################################################################################
> > ##comando para ler um arquivo ".dbf"
> >
> >             ##
> > ##
> >
> >                                            ##
> > ##library("foreign")
> >
> >                               ##
> > ##
> >
> >                                            ##
> > ##read.dbf("I:/qgis_1/exercicio_buffer_L1/testes/teste_1/corte_estrada_aneis.dbf")
> >                                            ##
> > ##
> >
> >                                            ##
> >
> > ###########################################################################################
> > ##
> > ##Salvando tudo em forma de lista
> >
> > library("foreign")
> >
> > setwd("I:/qgis_1/exercicio_buffer_L1/testes/teste_1")
> >
> > arquivos <- list.files(pattern="\\.dbf$")
> >
> > x <- lapply(arquivos, read.dbf)
> >
> > ##Exportando os comprimentos de cada estrada cortada por um anel
> >
> > for (i in 1:91){
> >
> >     y[[i]] <- x[[i]]
> >     vector_length[i] <- sum(y[[i]][,2])
> >
> >                }
> >
> >
> > ##########################################################################################
> >
> > Assim como mostrado no exemplo acima estou lendo um arquivo chamado "corte_estrada_aneis.dbf",
> > todavia possui um banco com 91 desses arquivos numerados de forma que seus
> > nomes ficam, por exemplo: corte_estrada_aneis.1dbf,
> > corte_estrada_aneis2.dbf, corte_estrada_aneis3.dbf, ... até finalmente corte_estrada_aneis91.dbf.
> > O problema na leitura dos .dbf consiste que a lógica acima usada por mim
> > faz com que a ordenação saia errada, ou seja, ele faz a leitura dos
> >  arquivos corte_estrada_aneis1.dbf, corte_estrada_aneis12.dbf, corte_estrada_aneis13.dbf
> > e assim por diante. Uma tentativa minha, porém não muito bem sucedida foi a
> > seguinte:
> >
> >
> > #########################################################################################
> >
> > library("foreign")
> >
> > for (i in 1:9){
> >
> > g[i] <-
> > read.dbf("I:/qgis_1/exercicio_buffer_L1/testes/teste_1/corte_estrada_aneis[i].dbf")
> >
> >                }
> >
> > g
> >
> >
> > #########################################################################################
> >
> > Mas como tudo esta contido em " " o índice [i] será lido literalmente.
> > Peço ajuda aos colegas para poder solucinar este problema, seja com a minha
> > lógica ou com alguma idéia diferente.
> >
> > Abraços a todos!
> >
> > Paulo Henrique de A. S. Pimenta.
> >
> > Graduando em Meteorologia (Bacharelado) - IAG/USP.
> > Fone: +5511981318435.
> >
> > _______________________________________________
> > R-br mailing list
> > R-br em listas.c3sl.ufpr.br
> > https://listas.inf.ufpr.br/cgi-bin/mailman/listinfo/r-br
> > Leia o guia de postagem (http://www.leg.ufpr.br/r-br-guia) e forneça
> > código mínimo reproduzível.
> >
> 
> 
> 
> -- 
> Grato
> Augusto C. A. Ribas
> 
> Site Pessoal: http://recologia.com.br/ <http://augustoribas.heliohost.org>
> Github: https://github.com/Squiercg
> Lattes: http://lattes.cnpq.br/7355685961127056
> -------------- Próxima Parte ----------
> Um anexo em HTML foi limpo...
> URL: <http://listas.inf.ufpr.br/pipermail/r-br/attachments/20141113/eaa31741/attachment-0001.html>
> 
> ------------------------------
> 
> Subject: Legenda do Digest
> 
> _______________________________________________
> R-br mailing list
> R-br em listas.c3sl.ufpr.br
> https://listas.inf.ufpr.br/cgi-bin/mailman/listinfo/r-br
> 
> 
> ------------------------------
> 
> Fim da Digest R-br, volume 47, assunto 14
> *****************************************
 		 	   		   		 	   		  
-------------- Próxima Parte ----------
Um anexo em HTML foi limpo...
URL: <http://listas.inf.ufpr.br/pipermail/r-br/attachments/20141116/3fbf4d93/attachment.html>


Mais detalhes sobre a lista de discussão R-br