TeorĂ­a

La minerĂ­a de texto (TM) es el proceso de extraer informaciĂłn Ăștil, patrones o conocimientos de textos no estructurados.

Consta de tres etapas:
1. Obtener datos: El Reconocimiento Óptico de Caracteres (OCR) es una tecnologĂ­a que permite convertir imĂĄgenes de texto en texto editable. TambiĂ©n es conocido como extracciĂłn de texto de imĂĄgenes.
2. Explorar datos: RepresentaciĂłn grĂĄfica o visual de los datos para su interpretaciĂłn. Los metodos mĂĄs comunes son el AnĂĄlisis de Sentimientos, la Nube de Palabras y el Topic Modeling.
3. Anålisis predictivo: son las técnicas y modelos estadísticos para predecir resultados futuros. Los modelos mås usados son el Random Forestm redes neuronales y regrsiones.

Instalar paquetes y llamar librerĂ­as

# install.packages("tidyverse") # ManipulaciĂłn de datos
library(tidyverse)
# install.packages("tesseract") # Reconocimiento Óptimo de Caracteres
library(tesseract)
# install.packages("magick") # 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 aplicar funciĂłn a cada elemento de un vector
library(purrr)

Etapa 1. Obtener datos mediante OCR

De imĂĄgen PNG a texto en Word

imagen1 <- image_read("/Users/anapaualvear/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") #Guardar el doc1 en la compu

De imågen PNG en español a texto en Word

imagen2 <- image_read("/Users/anapaualvear/Downloads/imagen2.PNG")
tesseract_download("spa")
## Training data already exists. Overwriting /Users/anapaualvear/Library/Application Support/tesseract5/tessdata/spa.traineddata
## [1] "/Users/anapaualvear/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(texto2) #Pega el texto en el doc1
#print(doc2, target="texto2.docx") #Guardar el doc1 en la compu

Actividad 1.

#De PDF a texto en word
pdf_eso <- pdf_convert("/Users/anapaualvear/Downloads/eso.pdf", dpi=600) %>% map(ocr)
## Converting page 1 to eso_1.png... done!
## Converting page 2 to eso_2.png... done!
#Repetir pasos previos para convertir imĂĄgenes a texto en word. 
imagen1.1 <-image_read("/Users/anapaualvear/Desktop/modulo 2 R/eso_1.png")
tesseract_download("spa")
## Training data already exists. Overwriting /Users/anapaualvear/Library/Application Support/tesseract5/tessdata/spa.traineddata
## [1] "/Users/anapaualvear/Library/Application Support/tesseract5/tessdata/spa.traineddata"
texto1.1 <-ocr(imagen1.1,engine=tesseract("spa"))
doc1.1 <- read_docx() #Crea un documento de Word en blanco
doc1.1 <- doc1.1 %>% body_add_par(texto1.1) #Pega el texto en el doc1

imagen1.2 <-image_read("/Users/anapaualvear/Desktop/modulo 2 R/eso_2.png")
texto1.2 <-ocr(imagen1.2,engine=tesseract("spa"))
doc1.2 <- read_docx() #Crea un documento de Word en blanco
doc1.2 <- doc1.2 %>% body_add_par(texto1.1) %>% body_add_par(texto1.2)#Pega el texto en el doc1
print(doc1.2, target= "ESO_texto.docx") #Guarda el doc en la compu

Etapa 2. Explorar datos mediante anĂĄlisis de sentimiento

Instalar paquetes y llamar librerĂ­as

#install.packages("syuzhet") #AnĂĄlisis de sentimientos 
library(syuzhet)
#install.packages("tm") #MinerĂ­a de texto 
library(tm)
#install.packages("wordcloud")
library(wordcloud)
#install.packages(RColorBrwer)
library(RColorBrewer)

AnĂĄlisis de emociones y sentimientos

texto <- pdf_eso
texto_palabras <- get_tokens(texto) #Separar texto por palabras
emociones <- get_nrc_sentiment(texto_palabras, language = "spanish")
#Alegria, 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", "habian", "hecho"))
wordcloud(words=palabras, min.freq=2, rot.per =0, random.order=FALSE)

LS0tCnRpdGxlOiAiVGV4dCBNaW5pbmciCmF1dGhvcjogIkFuYSBQYXVsYSBBbHZlYXIgQ2FudMO6IgpkYXRlOiAiMjAyNS0wMi0xNyIKb3V0cHV0OiAKICBodG1sX2RvY3VtZW50OgogICAgdG9jOiBUUlVFCiAgICB0b2NfZmxvYXQ6IFRSVUUKICAgIGNvZGVfZG93bmxvYWQ6IFRSVUUKICAgIHRoZW1lOiBjb3NtbwotLS0KCiFbXSgvVXNlcnMvYW5hcGF1YWx2ZWFyL0Rlc2t0b3AvbW9kdWxvIDIgUi9naXBoeS5naWYpCgojIDxzcGFuIHN0eWxlPSJjb2xvcjpyZWQ7Ij5UZW9yw61hPC9zcGFuPgpMYSAqKm1pbmVyw61hIGRlIHRleHRvIChUTSkqKiBlcyBlbCBwcm9jZXNvIGRlIGV4dHJhZXIgaW5mb3JtYWNpw7NuIMO6dGlsLCBwYXRyb25lcyBvIGNvbm9jaW1pZW50b3MgZGUgdGV4dG9zIG5vIGVzdHJ1Y3R1cmFkb3MuICAKCkNvbnN0YSBkZSB0cmVzIGV0YXBhczogIAoxLiBPYnRlbmVyIGRhdG9zOiBFbCAqKlJlY29ub2NpbWllbnRvIMOTcHRpY28gZGUgQ2FyYWN0ZXJlcyAoT0NSKSoqIGVzIHVuYSB0ZWNub2xvZ8OtYSBxdWUgcGVybWl0ZSBjb252ZXJ0aXIgaW3DoWdlbmVzIGRlIHRleHRvIGVuIHRleHRvIGVkaXRhYmxlLiBUYW1iacOpbiBlcyBjb25vY2lkbyBjb21vICoqZXh0cmFjY2nDs24gZGUgdGV4dG8gZGUgaW3DoWdlbmVzKiouICAKMi4gRXhwbG9yYXIgZGF0b3M6IFJlcHJlc2VudGFjacOzbiBncsOhZmljYSBvIHZpc3VhbCBkZSBsb3MgZGF0b3MgcGFyYSBzdSBpbnRlcnByZXRhY2nDs24uIExvcyBtZXRvZG9zIG3DoXMgY29tdW5lcyBzb24gZWwgQW7DoWxpc2lzIGRlIFNlbnRpbWllbnRvcywgbGEgTnViZSBkZSBQYWxhYnJhcyB5IGVsIFRvcGljIE1vZGVsaW5nLiAgCjMuIEFuw6FsaXNpcyBwcmVkaWN0aXZvOiBzb24gbGFzIHTDqWNuaWNhcyB5IG1vZGVsb3MgZXN0YWTDrXN0aWNvcyBwYXJhIHByZWRlY2lyIHJlc3VsdGFkb3MgZnV0dXJvcy4gTG9zIG1vZGVsb3MgbcOhcyB1c2Fkb3Mgc29uIGVsIFJhbmRvbSBGb3Jlc3RtIHJlZGVzIG5ldXJvbmFsZXMgeSByZWdyc2lvbmVzLiAgCgojIDxzcGFuIHN0eWxlPSJjb2xvcjpyZWQ7Ij5JbnN0YWxhciBwYXF1ZXRlcyB5IGxsYW1hciBsaWJyZXLDrWFzPC9zcGFuPgpgYGB7ciBtZXNzYWdlPUZBTFNFLCB3YXJuaW5nPUZBTFNFfQojIGluc3RhbGwucGFja2FnZXMoInRpZHl2ZXJzZSIpICMgTWFuaXB1bGFjacOzbiBkZSBkYXRvcwpsaWJyYXJ5KHRpZHl2ZXJzZSkKIyBpbnN0YWxsLnBhY2thZ2VzKCJ0ZXNzZXJhY3QiKSAjIFJlY29ub2NpbWllbnRvIMOTcHRpbW8gZGUgQ2FyYWN0ZXJlcwpsaWJyYXJ5KHRlc3NlcmFjdCkKIyBpbnN0YWxsLnBhY2thZ2VzKCJtYWdpY2siKSAjIFBORwpsaWJyYXJ5KG1hZ2ljaykKIyBpbnN0YWxsLnBhY2thZ2VzKCJvZmZpY2VyIikgIyBPZmZpY2UgKHdvcmQpCmxpYnJhcnkob2ZmaWNlcikKIyBpbnN0YWxsLnBhY2thZ2VzKCJwZGZ0b29scyIpICMgUERGCmxpYnJhcnkocGRmdG9vbHMpCiNpbnN0YWxsLnBhY2thZ2VzKCJwdXJyciIpICNQYXJhIGxhIGZ1bmNpw7NuICJtYXAiIHBhcmEgYXBsaWNhciBmdW5jacOzbiBhIGNhZGEgZWxlbWVudG8gZGUgdW4gdmVjdG9yCmxpYnJhcnkocHVycnIpCmBgYAoKIyA8c3BhbiBzdHlsZT0iY29sb3I6cmVkOyI+RXRhcGEgMS4gT2J0ZW5lciBkYXRvcyBtZWRpYW50ZSBPQ1I8L3NwYW4+ICAKCiMjIDxzcGFuIHN0eWxlPSJjb2xvcjpyZWQ7Ij5EZSBpbcOhZ2VuIFBORyBhIHRleHRvIGVuIFdvcmQ8L3NwYW4+ICAKYGBge3J9CmltYWdlbjEgPC0gaW1hZ2VfcmVhZCgiL1VzZXJzL2FuYXBhdWFsdmVhci9Eb3dubG9hZHMvaW1hZ2VuMS5QTkciKQp0ZXh0bzEgPC0gb2NyKGltYWdlbjEpCnRleHRvMQpkb2MxIDwtIHJlYWRfZG9jeCgpICNDcmVhIHVuIGRvY3VtZW50byBkZSBXb3JkIGVuIGJsYW5jbwpkb2MxIDwtIGRvYzEgJT4lIGJvZHlfYWRkX3Bhcih0ZXh0bzEpICNQZWdhIGVsIHRleHRvIGVuIGVsIGRvYzEKI3ByaW50KGRvYzEsIHRhcmdldD0idGV4dG8xLmRvY3giKSAjR3VhcmRhciBlbCBkb2MxIGVuIGxhIGNvbXB1CmBgYAoKIyMgPHNwYW4gc3R5bGU9ImNvbG9yOnJlZDsiPkRlIGltw6FnZW4gUE5HIGVuIGVzcGHDsW9sIGEgdGV4dG8gZW4gV29yZDwvc3Bhbj4KYGBge3J9CmltYWdlbjIgPC0gaW1hZ2VfcmVhZCgiL1VzZXJzL2FuYXBhdWFsdmVhci9Eb3dubG9hZHMvaW1hZ2VuMi5QTkciKQp0ZXNzZXJhY3RfZG93bmxvYWQoInNwYSIpCnRleHRvMiA8LSBvY3IoaW1hZ2VuMiwgZW5naW5lID0gdGVzc2VyYWN0KCJzcGEiKSkKdGV4dG8yCmRvYzIgPC0gcmVhZF9kb2N4KCkgI0NyZWEgdW4gZG9jdW1lbnRvIGRlIFdvcmQgZW4gYmxhbmNvCmRvYzIgPC0gZG9jMiAlPiUgYm9keV9hZGRfcGFyKHRleHRvMikgI1BlZ2EgZWwgdGV4dG8gZW4gZWwgZG9jMQojcHJpbnQoZG9jMiwgdGFyZ2V0PSJ0ZXh0bzIuZG9jeCIpICNHdWFyZGFyIGVsIGRvYzEgZW4gbGEgY29tcHUKYGBgCgojIyA8c3BhbiBzdHlsZT0iY29sb3I6cmVkOyI+QWN0aXZpZGFkIDEuPC9zcGFuPgpgYGB7cn0KI0RlIFBERiBhIHRleHRvIGVuIHdvcmQKcGRmX2VzbyA8LSBwZGZfY29udmVydCgiL1VzZXJzL2FuYXBhdWFsdmVhci9Eb3dubG9hZHMvZXNvLnBkZiIsIGRwaT02MDApICU+JSBtYXAob2NyKQojUmVwZXRpciBwYXNvcyBwcmV2aW9zIHBhcmEgY29udmVydGlyIGltw6FnZW5lcyBhIHRleHRvIGVuIHdvcmQuIApgYGAKCmBgYHtyfQppbWFnZW4xLjEgPC1pbWFnZV9yZWFkKCIvVXNlcnMvYW5hcGF1YWx2ZWFyL0Rlc2t0b3AvbW9kdWxvIDIgUi9lc29fMS5wbmciKQp0ZXNzZXJhY3RfZG93bmxvYWQoInNwYSIpCnRleHRvMS4xIDwtb2NyKGltYWdlbjEuMSxlbmdpbmU9dGVzc2VyYWN0KCJzcGEiKSkKZG9jMS4xIDwtIHJlYWRfZG9jeCgpICNDcmVhIHVuIGRvY3VtZW50byBkZSBXb3JkIGVuIGJsYW5jbwpkb2MxLjEgPC0gZG9jMS4xICU+JSBib2R5X2FkZF9wYXIodGV4dG8xLjEpICNQZWdhIGVsIHRleHRvIGVuIGVsIGRvYzEKCmltYWdlbjEuMiA8LWltYWdlX3JlYWQoIi9Vc2Vycy9hbmFwYXVhbHZlYXIvRGVza3RvcC9tb2R1bG8gMiBSL2Vzb18yLnBuZyIpCnRleHRvMS4yIDwtb2NyKGltYWdlbjEuMixlbmdpbmU9dGVzc2VyYWN0KCJzcGEiKSkKZG9jMS4yIDwtIHJlYWRfZG9jeCgpICNDcmVhIHVuIGRvY3VtZW50byBkZSBXb3JkIGVuIGJsYW5jbwpkb2MxLjIgPC0gZG9jMS4yICU+JSBib2R5X2FkZF9wYXIodGV4dG8xLjEpICU+JSBib2R5X2FkZF9wYXIodGV4dG8xLjIpI1BlZ2EgZWwgdGV4dG8gZW4gZWwgZG9jMQpwcmludChkb2MxLjIsIHRhcmdldD0gIkVTT190ZXh0by5kb2N4IikgI0d1YXJkYSBlbCBkb2MgZW4gbGEgY29tcHUKYGBgCgojIDxzcGFuIHN0eWxlPSJjb2xvcjpyZWQ7Ij5FdGFwYSAyLiBFeHBsb3JhciBkYXRvcyBtZWRpYW50ZSBhbsOhbGlzaXMgZGUgc2VudGltaWVudG88L3NwYW4+CiMjIDxzcGFuIHN0eWxlPSJjb2xvcjpyZWQ7Ij5JbnN0YWxhciBwYXF1ZXRlcyB5IGxsYW1hciBsaWJyZXLDrWFzPC9zcGFuPgpgYGB7ciBtZXNzYWdlPUZBTFNFLCB3YXJuaW5nPUZBTFNFfQojaW5zdGFsbC5wYWNrYWdlcygic3l1emhldCIpICNBbsOhbGlzaXMgZGUgc2VudGltaWVudG9zIApsaWJyYXJ5KHN5dXpoZXQpCiNpbnN0YWxsLnBhY2thZ2VzKCJ0bSIpICNNaW5lcsOtYSBkZSB0ZXh0byAKbGlicmFyeSh0bSkKI2luc3RhbGwucGFja2FnZXMoIndvcmRjbG91ZCIpCmxpYnJhcnkod29yZGNsb3VkKQojaW5zdGFsbC5wYWNrYWdlcyhSQ29sb3JCcndlcikKbGlicmFyeShSQ29sb3JCcmV3ZXIpCmBgYAoKIyMgPHNwYW4gc3R5bGU9ImNvbG9yOnJlZDsiPkFuw6FsaXNpcyBkZSBlbW9jaW9uZXMgeSBzZW50aW1pZW50b3M8L3NwYW4+CmBgYHtyfQp0ZXh0byA8LSBwZGZfZXNvCnRleHRvX3BhbGFicmFzIDwtIGdldF90b2tlbnModGV4dG8pICNTZXBhcmFyIHRleHRvIHBvciBwYWxhYnJhcwplbW9jaW9uZXMgPC0gZ2V0X25yY19zZW50aW1lbnQodGV4dG9fcGFsYWJyYXMsIGxhbmd1YWdlID0gInNwYW5pc2giKQojQWxlZ3JpYSwgVHJpc3RlemEsIElyYSwgTWllZG8sIFNvcnByZXNhLCBBc2NvLCBBbnRpY2lwYWNpw7NuLCBDb25maWFuemEKYmFycGxvdChjb2xTdW1zKHByb3AudGFibGUoZW1vY2lvbmVzWywxOjhdKSkpCnNlbnRpbWllbnRvcyA8LSAoZW1vY2lvbmVzJG5lZ2F0aXZlKi0xKStlbW9jaW9uZXMkcG9zaXRpdmUKc2ltcGxlX3Bsb3Qoc2VudGltaWVudG9zKQpgYGAKCiMjIDxzcGFuIHN0eWxlPSJjb2xvcjpyZWQ7Ij5OdWJlIGRlIHBhbGFicmFzPC9zcGFuPgpgYGB7ciBtZXNzYWdlPUZBTFNFLCB3YXJuaW5nPUZBTFNFfQpwYWxhYnJhcyA8LSB0ZXh0b19wYWxhYnJhcwpwYWxhYnJhcyA8LSByZW1vdmVXb3JkcyhwYWxhYnJhcywgCiAgICAgICAgICAgICAgICAgICAgICAgIGMoc3RvcHdvcmRzKCJzcGFuaXNoIiksImhhY2lhIiwgImhhYmlhbiIsICJoZWNobyIpKQp3b3JkY2xvdWQod29yZHM9cGFsYWJyYXMsIG1pbi5mcmVxPTIsIHJvdC5wZXIgPTAsIHJhbmRvbS5vcmRlcj1GQUxTRSkKYGBgCgo=