TeorĂ­a

La minerĂ­a de texto(TM) es el proceso de extraer informaciĂ³n util, patrones o conocimiento de textos no estructurados

Consta de tres etapas:

  1. Obtener datos: El Reconocimiento Ă“ptico de Caracteres (OCR) es una tecnologĂ­a que permite convertir imagenes de texto en texto editable. TambiĂ©n es conocido como extracciĂ³n de de tecto de imĂ¡genes.

  2. Explorar datos: RepresentaciĂ³n grĂ¡fica o visual de los datos para su interpretaciĂ³n, Los mĂ©todos mĂ¡s comunes son el anĂ¡lisis de Sentimientos, la nube de Palrbaas y el Topic Modeling.

  3. AnĂ¡lisis Predictivo: son las tĂ©cnicas y modelos estadisticos para predecir resultados futuos. Los modelos mĂ¡s usados son el Random Forest, redes neuronales y regresiones.

Instalar paqueteles y llamar librerĂ­as

#install.packages("tidyverse") #ManipulaciĂ³n de datos 
library(tidyverse)
#install.packages("tesseract") #OCR (reconocimiento optico de caracteres)
library(tesseract)
#install.packages("magick") #imagenes en png 
library(magick)
#install.packages("officer") #office(word)
library(officer)
#install.packages("pdftools")#pdf 
library(pdftools)
#install.packages("purrr") #para la funciĂ³n "map" para aplicarf una funciĂ³n a cada elemento de un vector.
library(purrr)

Etapa 1. Obtener datos mediante OCR

De imagen PNG a texto en Word

imagen1 <- image_read("/Users/vivi/Downloads/imagen1.PNG")
texto1 <- ocr(imagen1)
texto1
## [1] "Linear regression with one variable x is also known as univariate linear regression\nor simple linear regression. Simple linear regression is used to predict a single\noutput from a single input. This is an example of supervised learning, which means\nthat the data is labeled, i.e., the output values are known in the training data. Let us\nfit a line through the data using simple linear regression as shown in Fig. 4.1.\n"
doc1 <- read_docx() #Crea un documento de Word en blanco
doc1 <- doc1 %>% body_add_par(texto1) #Pega el texto en el doc1
print(doc1, target="texto1.docx") #Guarda el doc 1 en la compu

De imagen PNG en español a texto en Word

imagen2 <- image_read("/Users/vivi/Downloads/imagen2.PNG")
tesseract_download("spa")
## Training data already exists. Overwriting /Users/vivi/Library/Application Support/tesseract5/tessdata/spa.traineddata
## [1] "/Users/vivi/Library/Application Support/tesseract5/tessdata/spa.traineddata"
texto2 <- ocr(imagen2, engine = tesseract("spa"))
texto2
## [1] "Un importante, y quizĂ¡ controversial, asunto polĂ­tico es el que se refiere al efecto del salario mĂ­nimo sobre\nlas tasas de desempleo en diversos grupos de trabajadores. Aunque este problema puede ser estudiado con\ndiversos tipos de datos (corte transversal, series de tiempo o datos de panel), suelen usarse las series de\ntiempo para observar los efectos agregados. En la tabla 1.3 se presenta un ejemplo de una base de datos\nde series de tiempo sobre tasas de desempleo y salarios mĂ­nimos.\n"
doc2 <- read_docx() #Crea un documento de Word en blanco
doc2 <- doc2 %>% body_add_par(texto1) #Pega el texto en el doc1
print(doc2, target="texto2.docx") #Guarda el doc 1 en la compu

Actividad 1. Eso

#De PDF a texto en Word 
pdf_eso <- pdf_convert("/Users/vivi/Downloads/eso.pdf", dpi=600) %>% map (ocr)
## Converting page 1 to eso_1.png... done!
## Converting page 2 to eso_2.png... done!
eso1 <-image_read("/Users/vivi/Desktop/eso_1.png") 
textoeso1<- ocr(eso1, engine= tesseract('spa'))

eso2 <-image_read("/Users/vivi/Desktop/eso_2.png")
textoeso2<- ocr(eso2, engine= tesseract('spa'))

doc3 <- read_docx()
doc3 <- doc3 %>% body_add_par(textoeso1)
doc3 <- doc3 %>% body_add_par(textoeso2)

print(doc3, target= "Texto_eso.docx")

Etapa 2. Explorar Datos

Instalar paquetes y llamar librerĂ­as

#install.packages("syuzhet") #AnĂ¡lisis de Sentimientos
library(syuzhet)
#install.packages("tm") #MĂ­neria de texto
library(tm)
#install.packages("wordcloud")
library(wordcloud)
#install.packages("RColoeBrewer")
library(RColorBrewer)

AnĂ¡lisis de Emociones y Sentimientos

texto <-pdf_eso
texto_palabras <- get_tokens(texto)
emociones <- get_nrc_sentiment(texto_palabras, language= "spanish")
#AlegrĂ­a, Tristeza, Ira, Miedo, Sorpresa, Asco, AnticipaciĂ³n, Confianza 
barplot(colSums(prop.table(emociones[,1:8])))

sentimientos <-(emociones$negative*-1)+emociones$positive
simple_plot(sentimientos)

## Nube de Palabras

palabras <- texto_palabras 
palabras <-removeWords(palabras,
                       c(stopwords("Spanish"),"hacia","habia","habian","hecho"))
wordcloud(words=palabras, min.freq =2, rot.per =0, random.order=FALSE)
## Warning in tm_map.SimpleCorpus(corpus, tm::removePunctuation): transformation
## drops documents
## Warning in tm_map.SimpleCorpus(corpus, function(x) tm::removeWords(x,
## tm::stopwords())): transformation drops documents

LS0tCnRpdGxlOiAiVGV4dCBNaW5pbmciCmF1dGhvcjogIlZpdmlhbmEgRHVyw6FuXyBBMDA4Mzc3NzYiCmRhdGU6ICIyMDI1LTAyLTE3IgpvdXRwdXQ6IAogIGh0bWxfZG9jdW1lbnQ6CiAgICB0b2M6IFRSVUUgCiAgICB0b2NfZmxvYXQ6IFRSVUUgCiAgICBjb2RlX2Rvd25sb2FkOiBUUlVFCiAgICB0aGVtZTogY29zbW8gCi0tLQohW10oL1VzZXJzL3ZpdmkvRGVza3RvcC8zb1pxLmdpZikKCgojIDxzcGFuIHN0eWxlPSJjb2xvcjogcmVkOyI+VGVvcsOtYTwvc3Bhbj4KCkxhICoqbWluZXLDrWEgZGUgdGV4dG8oVE0pKiogZXMgZWwgcHJvY2VzbyBkZSBleHRyYWVyIGluZm9ybWFjacOzbiB1dGlsLCBwYXRyb25lcyBvIGNvbm9jaW1pZW50byBkZSB0ZXh0b3Mgbm8gZXN0cnVjdHVyYWRvcwogCkNvbnN0YSBkZSB0cmVzIGV0YXBhczoKCjEuIE9idGVuZXIgZGF0b3M6IEVsICoqUmVjb25vY2ltaWVudG8gw5NwdGljbyBkZSBDYXJhY3RlcmVzIChPQ1IpKiogZXMgdW5hIHRlY25vbG9nw61hIHF1ZSBwZXJtaXRlIGNvbnZlcnRpciBpbWFnZW5lcyBkZSB0ZXh0byBlbiB0ZXh0byBlZGl0YWJsZS4gVGFtYmnDqW4gZXMgY29ub2NpZG8gY29tbyAqKmV4dHJhY2Npw7NuIGRlIGRlIHRlY3RvIGRlIGltw6FnZW5lcyoqLgoKMi4gRXhwbG9yYXIgZGF0b3M6IFJlcHJlc2VudGFjacOzbiBncsOhZmljYSBvIHZpc3VhbCBkZSBsb3MgZGF0b3MgcGFyYSBzdSBpbnRlcnByZXRhY2nDs24sIExvcyBtw6l0b2RvcyBtw6FzIGNvbXVuZXMgc29uIGVsIGFuw6FsaXNpcyBkZSBTZW50aW1pZW50b3MsIGxhIG51YmUgZGUgUGFscmJhYXMgeSBlbCBUb3BpYyBNb2RlbGluZy4gCgozLiBBbsOhbGlzaXMgUHJlZGljdGl2bzogc29uIGxhcyB0w6ljbmljYXMgeSBtb2RlbG9zIGVzdGFkaXN0aWNvcyBwYXJhIHByZWRlY2lyIHJlc3VsdGFkb3MgZnV0dW9zLiBMb3MgbW9kZWxvcyBtw6FzIHVzYWRvcyBzb24gZWwgUmFuZG9tIEZvcmVzdCwgcmVkZXMgbmV1cm9uYWxlcyB5IHJlZ3Jlc2lvbmVzLiAKCiMgPHNwYW4gc3R5bGU9ImNvbG9yOiByZWQ7Ij4gSW5zdGFsYXIgcGFxdWV0ZWxlcyB5IGxsYW1hciBsaWJyZXLDrWFzIDwvc3Bhbj4KYGBge3IgbWVzc2FnZT1GQUxTRSwgd2FybmluZz1GQUxTRX0KI2luc3RhbGwucGFja2FnZXMoInRpZHl2ZXJzZSIpICNNYW5pcHVsYWNpw7NuIGRlIGRhdG9zIApsaWJyYXJ5KHRpZHl2ZXJzZSkKI2luc3RhbGwucGFja2FnZXMoInRlc3NlcmFjdCIpICNPQ1IgKHJlY29ub2NpbWllbnRvIG9wdGljbyBkZSBjYXJhY3RlcmVzKQpsaWJyYXJ5KHRlc3NlcmFjdCkKI2luc3RhbGwucGFja2FnZXMoIm1hZ2ljayIpICNpbWFnZW5lcyBlbiBwbmcgCmxpYnJhcnkobWFnaWNrKQojaW5zdGFsbC5wYWNrYWdlcygib2ZmaWNlciIpICNvZmZpY2Uod29yZCkKbGlicmFyeShvZmZpY2VyKQojaW5zdGFsbC5wYWNrYWdlcygicGRmdG9vbHMiKSNwZGYgCmxpYnJhcnkocGRmdG9vbHMpCiNpbnN0YWxsLnBhY2thZ2VzKCJwdXJyciIpICNwYXJhIGxhIGZ1bmNpw7NuICJtYXAiIHBhcmEgYXBsaWNhcmYgdW5hIGZ1bmNpw7NuIGEgY2FkYSBlbGVtZW50byBkZSB1biB2ZWN0b3IuCmxpYnJhcnkocHVycnIpCmBgYAojIDxzcGFuIHN0eWxlPSJjb2xvcjogcmVkOyI+IEV0YXBhIDEuIE9idGVuZXIgZGF0b3MgbWVkaWFudGUgT0NSIDwvc3Bhbj4KIyMgPHNwYW4gc3R5bGU9ImNvbG9yOiByZWQ7Ij5EZSBpbWFnZW4gUE5HIGEgdGV4dG8gZW4gV29yZCA8L3NwYW4+CmBgYHtyfQppbWFnZW4xIDwtIGltYWdlX3JlYWQoIi9Vc2Vycy92aXZpL0Rvd25sb2Fkcy9pbWFnZW4xLlBORyIpCnRleHRvMSA8LSBvY3IoaW1hZ2VuMSkKdGV4dG8xCmRvYzEgPC0gcmVhZF9kb2N4KCkgI0NyZWEgdW4gZG9jdW1lbnRvIGRlIFdvcmQgZW4gYmxhbmNvCmRvYzEgPC0gZG9jMSAlPiUgYm9keV9hZGRfcGFyKHRleHRvMSkgI1BlZ2EgZWwgdGV4dG8gZW4gZWwgZG9jMQpwcmludChkb2MxLCB0YXJnZXQ9InRleHRvMS5kb2N4IikgI0d1YXJkYSBlbCBkb2MgMSBlbiBsYSBjb21wdQpgYGAKIyMgPHNwYW4gc3R5bGU9ImNvbG9yOiByZWQ7Ij5EZSBpbWFnZW4gUE5HIGVuIGVzcGHDsW9sIGEgdGV4dG8gZW4gV29yZCA8L3NwYW4+CmBgYHtyfQppbWFnZW4yIDwtIGltYWdlX3JlYWQoIi9Vc2Vycy92aXZpL0Rvd25sb2Fkcy9pbWFnZW4yLlBORyIpCnRlc3NlcmFjdF9kb3dubG9hZCgic3BhIikKdGV4dG8yIDwtIG9jcihpbWFnZW4yLCBlbmdpbmUgPSB0ZXNzZXJhY3QoInNwYSIpKQp0ZXh0bzIKZG9jMiA8LSByZWFkX2RvY3goKSAjQ3JlYSB1biBkb2N1bWVudG8gZGUgV29yZCBlbiBibGFuY28KZG9jMiA8LSBkb2MyICU+JSBib2R5X2FkZF9wYXIodGV4dG8xKSAjUGVnYSBlbCB0ZXh0byBlbiBlbCBkb2MxCnByaW50KGRvYzIsIHRhcmdldD0idGV4dG8yLmRvY3giKSAjR3VhcmRhIGVsIGRvYyAxIGVuIGxhIGNvbXB1CmBgYAoKIyMgPHNwYW4gc3R5bGU9ImNvbG9yOiByZWQ7Ij5BY3RpdmlkYWQgMS4gRXNvIDwvc3Bhbj4KYGBge3J9CiNEZSBQREYgYSB0ZXh0byBlbiBXb3JkIApwZGZfZXNvIDwtIHBkZl9jb252ZXJ0KCIvVXNlcnMvdml2aS9Eb3dubG9hZHMvZXNvLnBkZiIsIGRwaT02MDApICU+JSBtYXAgKG9jcikKZXNvMSA8LWltYWdlX3JlYWQoIi9Vc2Vycy92aXZpL0Rlc2t0b3AvZXNvXzEucG5nIikgCnRleHRvZXNvMTwtIG9jcihlc28xLCBlbmdpbmU9IHRlc3NlcmFjdCgnc3BhJykpCgplc28yIDwtaW1hZ2VfcmVhZCgiL1VzZXJzL3ZpdmkvRGVza3RvcC9lc29fMi5wbmciKQp0ZXh0b2VzbzI8LSBvY3IoZXNvMiwgZW5naW5lPSB0ZXNzZXJhY3QoJ3NwYScpKQoKZG9jMyA8LSByZWFkX2RvY3goKQpkb2MzIDwtIGRvYzMgJT4lIGJvZHlfYWRkX3Bhcih0ZXh0b2VzbzEpCmRvYzMgPC0gZG9jMyAlPiUgYm9keV9hZGRfcGFyKHRleHRvZXNvMikKCnByaW50KGRvYzMsIHRhcmdldD0gIlRleHRvX2Vzby5kb2N4IikKYGBgCgojIDxzcGFuIHN0eWxlPSJjb2xvcjogcmVkOyI+RXRhcGEgMi4gRXhwbG9yYXIgRGF0b3M8L3NwYW4+CiMjIDxzcGFuIHN0eWxlPSJjb2xvcjogcmVkOyI+SW5zdGFsYXIgcGFxdWV0ZXMgeSBsbGFtYXIgbGlicmVyw61hcyA8L3NwYW4+CmBgYHtyIG1lc3NhZ2U9RkFMU0UsIHdhcm5pbmc9RkFMU0V9CiNpbnN0YWxsLnBhY2thZ2VzKCJzeXV6aGV0IikgI0Fuw6FsaXNpcyBkZSBTZW50aW1pZW50b3MKbGlicmFyeShzeXV6aGV0KQojaW5zdGFsbC5wYWNrYWdlcygidG0iKSAjTcOtbmVyaWEgZGUgdGV4dG8KbGlicmFyeSh0bSkKI2luc3RhbGwucGFja2FnZXMoIndvcmRjbG91ZCIpCmxpYnJhcnkod29yZGNsb3VkKQojaW5zdGFsbC5wYWNrYWdlcygiUkNvbG9lQnJld2VyIikKbGlicmFyeShSQ29sb3JCcmV3ZXIpCmBgYAoKIyMgPHNwYW4gc3R5bGU9ImNvbG9yOiByZWQ7Ij5BbsOhbGlzaXMgZGUgRW1vY2lvbmVzIHkgU2VudGltaWVudG9zIDwvc3Bhbj4KYGBge3J9CnRleHRvIDwtcGRmX2Vzbwp0ZXh0b19wYWxhYnJhcyA8LSBnZXRfdG9rZW5zKHRleHRvKQplbW9jaW9uZXMgPC0gZ2V0X25yY19zZW50aW1lbnQodGV4dG9fcGFsYWJyYXMsIGxhbmd1YWdlPSAic3BhbmlzaCIpCiNBbGVncsOtYSwgVHJpc3RlemEsIElyYSwgTWllZG8sIFNvcnByZXNhLCBBc2NvLCBBbnRpY2lwYWNpw7NuLCBDb25maWFuemEgCmJhcnBsb3QoY29sU3Vtcyhwcm9wLnRhYmxlKGVtb2Npb25lc1ssMTo4XSkpKQpzZW50aW1pZW50b3MgPC0oZW1vY2lvbmVzJG5lZ2F0aXZlKi0xKStlbW9jaW9uZXMkcG9zaXRpdmUKc2ltcGxlX3Bsb3Qoc2VudGltaWVudG9zKQpgYGAKIyMgPHNwYW4gc3R5bGU9ImNvbG9yOiByZWQ7Ij5OdWJlIGRlIFBhbGFicmFzIDwvc3Bhbj4KYGBge3J9CnBhbGFicmFzIDwtIHRleHRvX3BhbGFicmFzIApwYWxhYnJhcyA8LXJlbW92ZVdvcmRzKHBhbGFicmFzLAogICAgICAgICAgICAgICAgICAgICAgIGMoc3RvcHdvcmRzKCJTcGFuaXNoIiksImhhY2lhIiwiaGFiaWEiLCJoYWJpYW4iLCJoZWNobyIpKQp3b3JkY2xvdWQod29yZHM9cGFsYWJyYXMsIG1pbi5mcmVxID0yLCByb3QucGVyID0wLCByYW5kb20ub3JkZXI9RkFMU0UpCmBgYAoK