TEORÍA

La minería de texto (TM) es el proceso de extraer información útil, patrones o conocimiento de textos no estructurados.

Consta de tres etapas:

  1. Obtener datos: El Reconocimiento Optico 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 métodos 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 Forest, redes neuronales y las regresiones.

Instalar paquetes y llamar librerías

#install.packages("tidyverse") #Manipulación de datos
library(tidyverse)
#install.packages("tesseract") #OCR
library(tesseract)
#install.packages("magick") #Recon PNG
library(magick)
#install.packages("officer") #Office (Word)
library(officer)
#install.packages("pdftools") #PDF
library(pdftools)
#install.packages("purrr")
library(purrr) #Para la función "map" para aplicar una función a cada elemento de un vector

Etapa 1. Obtener Datos mediante OCR

De imagen PNG a texto en word

imagen1 <- image_read("C:/Users/aleja/Pictures/Imagenes trabajos/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() # Crear 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 doc1 en la computadora

De imagen PNG a texto en word

imagen2 <- image_read("C:/Users/aleja/Pictures/Imagenes trabajos/imagen2.PNG")
tesseract_download("spa")
## Training data already exists. Overwriting C:\Users\aleja\AppData\Local\tesseract5\tesseract5\tessdata/spa.traineddata
## [1] "C:\\Users\\aleja\\AppData\\Local\\tesseract5\\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() # Crear un documento de Word en Blanco
doc2 <- doc2 %>% body_add_par(texto2) #pega el texto en el doc1
#print(doc2, target= "texto2.docx") #Guarda el doc2 en la computadora

Actividad 1. ESO

#De PDF a texto en word
pdf_eso <-pdf_convert("C:/Users/aleja/Pictures/Imagenes trabajos/eso.pdf", dpi = 600) %>% map(ocr)
## Converting page 1 to eso_1.png... done!
## Converting page 2 to eso_2.png... done!
# Repetir pasos precios para convertir imágenes a texto en word.
imgeso1 <- image_read("C:/Users/aleja/Pictures/Imagenes trabajos/eso_1.1.png")
imgeso2 <- image_read("C:/Users/aleja/Pictures/Imagenes trabajos/eso_1.2.png")
tesseract_download("spa")
## Training data already exists. Overwriting C:\Users\aleja\AppData\Local\tesseract5\tesseract5\tessdata/spa.traineddata
## [1] "C:\\Users\\aleja\\AppData\\Local\\tesseract5\\tesseract5\\tessdata/spa.traineddata"
texto1_ESO <- ocr(imgeso1, engine = "spa")
texto2_ESO <- ocr(imgeso2, engine = "spa")

doc3 <- read_docx() %>%
  body_add_par(texto1_ESO, style = "Normal") %>%
  body_add_par("", style = "Normal") %>%  # Espacio entre los textos
  body_add_par(texto2_ESO, style = "Normal")
print(doc3, target= "texto3.docx") #Guarda el doc2 en la computadora

Etapa 2, Explorar Datos mediante Análisis de sentimientos

Instalar paquetes y llamar a librerías

#install.packages("syuzhet") #Análisis de sentimientos
library("syuzhet")
#install.packages("tm") #Minería de texto
library("tm")
#install.packages("wordcloud") #Nube de palabras
library("wordcloud")
#install.packages("RColorBrewer")
library("RColorBrewer")

Análisis de Emociones y sentimientos

textoESO_ <- pdf_eso
texto_palabras <- get_tokens(textoESO_)
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"), "habia", "habian", "hacia", "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

R Markdown

This is an R Markdown document. Markdown is a simple formatting syntax for authoring HTML, PDF, and MS Word documents. For more details on using R Markdown see http://rmarkdown.rstudio.com.

When you click the Knit button a document will be generated that includes both content as well as the output of any embedded R code chunks within the document. You can embed an R code chunk like this:

summary(cars)
##      speed           dist       
##  Min.   : 4.0   Min.   :  2.00  
##  1st Qu.:12.0   1st Qu.: 26.00  
##  Median :15.0   Median : 36.00  
##  Mean   :15.4   Mean   : 42.98  
##  3rd Qu.:19.0   3rd Qu.: 56.00  
##  Max.   :25.0   Max.   :120.00

Including Plots

You can also embed plots, for example:

Note that the echo = FALSE parameter was added to the code chunk to prevent printing of the R code that generated the plot.

LS0tDQp0aXRsZTogIlRleHRfTWluaW5nIg0KYXV0aG9yOiAiU2FtYW50aGEiDQpkYXRlOiAiMjAyNS0wMi0xNyINCm91dHB1dDogDQogIGh0bWxfZG9jdW1lbnQ6DQogICAgdG9jOiBUUlVFDQogICAgdG9jX2Zsb2F0OiBUUlVFDQogICAgY29kZV9kb3dubG9hZDogVFJVRQ0KICAgIHRoZW1lOiBjb3Ntbw0KLS0tDQoNCiFbXSgiIkM6L1VzZXJzL2FsZWphL1BpY3R1cmVzL0ltYWdlbmVzIHRyYWJham9zL0l0LTIwMTcuanBnIiIpDQoNCiMgPHNwYW4gc3R5bGU9ImNvbG9yOiByZWQ7IiA+VEVPUsONQTwvU3BhbiA+DQoNCkxhICoqbWluZXLDrWEgZGUgdGV4dG8gKFRNKSoqIGVzIGVsIHByb2Nlc28gZGUgZXh0cmFlciBpbmZvcm1hY2nDs24gw7p0aWwsIHBhdHJvbmVzIG8gY29ub2NpbWllbnRvIGRlIHRleHRvcyBubyBlc3RydWN0dXJhZG9zLg0KDQoqKkNvbnN0YSBkZSB0cmVzIGV0YXBhczoqKg0KDQoxLiBPYnRlbmVyIGRhdG9zOiBFbCAqKlJlY29ub2NpbWllbnRvIE9wdGljbyBkZSBDYXJhY3RlcmVzIChPQ1IpKiogZXMgdW5hIHRlY25vbG9nw61hIHF1ZSBwZXJtaXRlIGNvbnZlcnRpciBpbcOhZ2VuZXMgZGUgdGV4dG8gZW4gdGV4dG8gZWRpdGFibGUuIFRhbWJpw6luIGVzIGNvbm9jaWRvIGNvbW8gKipleHRyYWNjacOzbiBkZSB0ZXh0byBkZSBpbcOhZ2VuZXMqKi4NCg0KMi4gRXhwbG9yYXIgZGF0b3M6IFJlcHJlc2VudGFjacOzbiBncsOhZmljYSBvIHZpc3VhbCBkZSBsb3MgZGF0b3MgcGFyYSBzdSBpbnRlcnByZXRhY2nDs24uIExvcyBtw6l0b2RvcyBtw6FzIGNvbXVuZXMgc29uIGVsIGFuw6FsaXNpcyBkZSBzZW50aW1pZW50b3MsIGxhIG51YmUgZGUgcGFsYWJyYXMgeSBlbCBUb3BpYyBNb2RlbGluZy4NCg0KMy4gQW7DoWxpc2lzIHByZWRpY3Rpdm86IFNvbiBsYXMgdMOpY25pY2FzIHkgbW9kZWxvcyBlc3RhZMOtc3RpY29zIHBhcmEgcHJlZGVjaXIgcmVzdWx0YWRvcyBmdXR1cm9zLiBMb3MgbW9kZWxvcyBtw6FzIHVzYWRvcyBzb24gZWwgUmFuZG9tIEZvcmVzdCwgcmVkZXMgbmV1cm9uYWxlcyB5IGxhcyByZWdyZXNpb25lcy4NCg0KIyA8c3BhbiBzdHlsZT0iY29sb3I6IGJsdWU7Ij5JbnN0YWxhciBwYXF1ZXRlcyB5IGxsYW1hciBsaWJyZXLDrWFzPHNwYW4+DQoNCmBgYHtyIG1lc3NhZ2U9RkFMU0UsIHdhcm5pbmc9RkFMU0V9DQojaW5zdGFsbC5wYWNrYWdlcygidGlkeXZlcnNlIikgI01hbmlwdWxhY2nDs24gZGUgZGF0b3MNCmxpYnJhcnkodGlkeXZlcnNlKQ0KI2luc3RhbGwucGFja2FnZXMoInRlc3NlcmFjdCIpICNPQ1INCmxpYnJhcnkodGVzc2VyYWN0KQ0KI2luc3RhbGwucGFja2FnZXMoIm1hZ2ljayIpICNSZWNvbiBQTkcNCmxpYnJhcnkobWFnaWNrKQ0KI2luc3RhbGwucGFja2FnZXMoIm9mZmljZXIiKSAjT2ZmaWNlIChXb3JkKQ0KbGlicmFyeShvZmZpY2VyKQ0KI2luc3RhbGwucGFja2FnZXMoInBkZnRvb2xzIikgI1BERg0KbGlicmFyeShwZGZ0b29scykNCiNpbnN0YWxsLnBhY2thZ2VzKCJwdXJyciIpDQpsaWJyYXJ5KHB1cnJyKSAjUGFyYSBsYSBmdW5jacOzbiAibWFwIiBwYXJhIGFwbGljYXIgdW5hIGZ1bmNpw7NuIGEgY2FkYSBlbGVtZW50byBkZSB1biB2ZWN0b3INCmBgYA0KIyA8c3BhbiBzdHlsZT0iY29sb3I6IHJlZDsiID5FdGFwYSAxLiBPYnRlbmVyIERhdG9zIG1lZGlhbnRlIE9DUiA8L1NwYW4gPg0KDQojIyA8c3BhbiBzdHlsZT0iY29sb3I6IHJlZDsiID5EZSBpbWFnZW4gUE5HIGEgdGV4dG8gZW4gd29yZDwvU3BhbiA+DQoNCmBgYHtyfQ0KaW1hZ2VuMSA8LSBpbWFnZV9yZWFkKCJDOi9Vc2Vycy9hbGVqYS9QaWN0dXJlcy9JbWFnZW5lcyB0cmFiYWpvcy9pbWFnZW4xLlBORyIpDQp0ZXh0bzEgPC0gb2NyKGltYWdlbjEpDQp0ZXh0bzENCmRvYzEgPC0gcmVhZF9kb2N4KCkgIyBDcmVhciB1biBkb2N1bWVudG8gZGUgV29yZCBlbiBCbGFuY28NCmRvYzEgPC0gZG9jMSAlPiUgYm9keV9hZGRfcGFyKHRleHRvMSkgI3BlZ2EgZWwgdGV4dG8gZW4gZWwgZG9jMQ0KI3ByaW50KGRvYzEsIHRhcmdldD0gInRleHRvMS5kb2N4IikgI0d1YXJkYSBlbCBkb2MxIGVuIGxhIGNvbXB1dGFkb3JhDQpgYGANCiMjIDxzcGFuIHN0eWxlPSJjb2xvcjogcmVkOyIgPkRlIGltYWdlbiBQTkcgYSB0ZXh0byBlbiB3b3JkPC9TcGFuID4NCg0KYGBge3J9DQppbWFnZW4yIDwtIGltYWdlX3JlYWQoIkM6L1VzZXJzL2FsZWphL1BpY3R1cmVzL0ltYWdlbmVzIHRyYWJham9zL2ltYWdlbjIuUE5HIikNCnRlc3NlcmFjdF9kb3dubG9hZCgic3BhIikNCnRleHRvMiA8LSBvY3IoaW1hZ2VuMiwgZW5naW5lID0gdGVzc2VyYWN0KCJzcGEiKSkNCnRleHRvMg0KZG9jMiA8LSByZWFkX2RvY3goKSAjIENyZWFyIHVuIGRvY3VtZW50byBkZSBXb3JkIGVuIEJsYW5jbw0KZG9jMiA8LSBkb2MyICU+JSBib2R5X2FkZF9wYXIodGV4dG8yKSAjcGVnYSBlbCB0ZXh0byBlbiBlbCBkb2MxDQojcHJpbnQoZG9jMiwgdGFyZ2V0PSAidGV4dG8yLmRvY3giKSAjR3VhcmRhIGVsIGRvYzIgZW4gbGEgY29tcHV0YWRvcmENCmBgYA0KIyMgPHNwYW4gc3R5bGU9ImNvbG9yOiByZWQ7IiA+QWN0aXZpZGFkIDEuIEVTTzwvU3BhbiA+DQpgYGB7cn0NCiNEZSBQREYgYSB0ZXh0byBlbiB3b3JkDQpwZGZfZXNvIDwtcGRmX2NvbnZlcnQoIkM6L1VzZXJzL2FsZWphL1BpY3R1cmVzL0ltYWdlbmVzIHRyYWJham9zL2Vzby5wZGYiLCBkcGkgPSA2MDApICU+JSBtYXAob2NyKQ0KIyBSZXBldGlyIHBhc29zIHByZWNpb3MgcGFyYSBjb252ZXJ0aXIgaW3DoWdlbmVzIGEgdGV4dG8gZW4gd29yZC4NCmltZ2VzbzEgPC0gaW1hZ2VfcmVhZCgiQzovVXNlcnMvYWxlamEvUGljdHVyZXMvSW1hZ2VuZXMgdHJhYmFqb3MvZXNvXzEuMS5wbmciKQ0KaW1nZXNvMiA8LSBpbWFnZV9yZWFkKCJDOi9Vc2Vycy9hbGVqYS9QaWN0dXJlcy9JbWFnZW5lcyB0cmFiYWpvcy9lc29fMS4yLnBuZyIpDQp0ZXNzZXJhY3RfZG93bmxvYWQoInNwYSIpDQp0ZXh0bzFfRVNPIDwtIG9jcihpbWdlc28xLCBlbmdpbmUgPSAic3BhIikNCnRleHRvMl9FU08gPC0gb2NyKGltZ2VzbzIsIGVuZ2luZSA9ICJzcGEiKQ0KDQpkb2MzIDwtIHJlYWRfZG9jeCgpICU+JQ0KICBib2R5X2FkZF9wYXIodGV4dG8xX0VTTywgc3R5bGUgPSAiTm9ybWFsIikgJT4lDQogIGJvZHlfYWRkX3BhcigiIiwgc3R5bGUgPSAiTm9ybWFsIikgJT4lICAjIEVzcGFjaW8gZW50cmUgbG9zIHRleHRvcw0KICBib2R5X2FkZF9wYXIodGV4dG8yX0VTTywgc3R5bGUgPSAiTm9ybWFsIikNCnByaW50KGRvYzMsIHRhcmdldD0gInRleHRvMy5kb2N4IikgI0d1YXJkYSBlbCBkb2MyIGVuIGxhIGNvbXB1dGFkb3JhDQpgYGANCg0KIyA8c3BhbiBzdHlsZT0iY29sb3I6IHJlZDsiID5FdGFwYSAyLCBFeHBsb3JhciBEYXRvcyBtZWRpYW50ZSBBbsOhbGlzaXMgZGUgc2VudGltaWVudG9zPC9TcGFuID4NCg0KIyMgPHNwYW4gc3R5bGU9ImNvbG9yOiBibHVlOyIgPkluc3RhbGFyIHBhcXVldGVzIHkgbGxhbWFyIGEgbGlicmVyw61hczwvU3BhbiA+DQpgYGB7ciBtZXNzYWdlPUZBTFNFLCB3YXJuaW5nPUZBTFNFfQ0KI2luc3RhbGwucGFja2FnZXMoInN5dXpoZXQiKSAjQW7DoWxpc2lzIGRlIHNlbnRpbWllbnRvcw0KbGlicmFyeSgic3l1emhldCIpDQojaW5zdGFsbC5wYWNrYWdlcygidG0iKSAjTWluZXLDrWEgZGUgdGV4dG8NCmxpYnJhcnkoInRtIikNCiNpbnN0YWxsLnBhY2thZ2VzKCJ3b3JkY2xvdWQiKSAjTnViZSBkZSBwYWxhYnJhcw0KbGlicmFyeSgid29yZGNsb3VkIikNCiNpbnN0YWxsLnBhY2thZ2VzKCJSQ29sb3JCcmV3ZXIiKQ0KbGlicmFyeSgiUkNvbG9yQnJld2VyIikNCmBgYA0KDQojIyA8c3BhbiBzdHlsZT0iY29sb3I6IHJlZDsiID5BbsOhbGlzaXMgZGUgRW1vY2lvbmVzIHkgc2VudGltaWVudG9zPC9TcGFuID4NCmBgYHtyfQ0KdGV4dG9FU09fIDwtIHBkZl9lc28NCnRleHRvX3BhbGFicmFzIDwtIGdldF90b2tlbnModGV4dG9FU09fKQ0KZW1vY2lvbmVzIDwtIGdldF9ucmNfc2VudGltZW50KHRleHRvX3BhbGFicmFzLCBsYW5ndWFnZSA9ICJzcGFuaXNoIikNCiNBbGVncsOtYSwgVHJpc3RlemEsIElyYSwgTWllZG8sIFNvcnByZXNhLCBBc2NvLCBBbnRpY2lwYWNpw7NuLCBDb25maWFuemENCmJhcnBsb3QoY29sU3Vtcyhwcm9wLnRhYmxlKGVtb2Npb25lc1ssMTo4XSkpKQ0Kc2VudGltaWVudG9zIDwtIChlbW9jaW9uZXMkbmVnYXRpdmUqLTErZW1vY2lvbmVzJHBvc2l0aXZlKQ0Kc2ltcGxlX3Bsb3Qoc2VudGltaWVudG9zKQ0KDQpgYGANCiMjIDxzcGFuIHN0eWxlPSJjb2xvcjogcmVkOyIgPk51YmUgZGUgcGFsYWJyYXM8L1NwYW4gPg0KYGBge3J9DQpwYWxhYnJhcyA8LSB0ZXh0b19wYWxhYnJhcw0KcGFsYWJyYXMgPC0gcmVtb3ZlV29yZHMocGFsYWJyYXMsIA0KYyhzdG9wd29yZHMoInNwYW5pc2giKSwgImhhYmlhIiwgImhhYmlhbiIsICJoYWNpYSIsICJoZWNobyIpKQ0Kd29yZGNsb3VkKHdvcmRzID0gcGFsYWJyYXMsIG1pbi5mcmVxID0yLCByb3QucGVyID0gMCwgcmFuZG9tLm9yZGVyID0gRkFMU0UpDQpgYGANCg0KDQpgYGB7ciBzZXR1cCwgaW5jbHVkZT1GQUxTRX0NCmtuaXRyOjpvcHRzX2NodW5rJHNldChlY2hvID0gVFJVRSkNCmBgYA0KDQojIyBSIE1hcmtkb3duDQoNClRoaXMgaXMgYW4gUiBNYXJrZG93biBkb2N1bWVudC4gTWFya2Rvd24gaXMgYSBzaW1wbGUgZm9ybWF0dGluZyBzeW50YXggZm9yIGF1dGhvcmluZyBIVE1MLCBQREYsIGFuZCBNUyBXb3JkIGRvY3VtZW50cy4gRm9yIG1vcmUgZGV0YWlscyBvbiB1c2luZyBSIE1hcmtkb3duIHNlZSA8aHR0cDovL3JtYXJrZG93bi5yc3R1ZGlvLmNvbT4uDQoNCldoZW4geW91IGNsaWNrIHRoZSAqKktuaXQqKiBidXR0b24gYSBkb2N1bWVudCB3aWxsIGJlIGdlbmVyYXRlZCB0aGF0IGluY2x1ZGVzIGJvdGggY29udGVudCBhcyB3ZWxsIGFzIHRoZSBvdXRwdXQgb2YgYW55IGVtYmVkZGVkIFIgY29kZSBjaHVua3Mgd2l0aGluIHRoZSBkb2N1bWVudC4gWW91IGNhbiBlbWJlZCBhbiBSIGNvZGUgY2h1bmsgbGlrZSB0aGlzOg0KDQpgYGB7ciBjYXJzfQ0Kc3VtbWFyeShjYXJzKQ0KYGBgDQoNCiMjIEluY2x1ZGluZyBQbG90cw0KDQpZb3UgY2FuIGFsc28gZW1iZWQgcGxvdHMsIGZvciBleGFtcGxlOg0KDQpgYGB7ciBwcmVzc3VyZSwgZWNobz1GQUxTRX0NCnBsb3QocHJlc3N1cmUpDQpgYGANCg0KTm90ZSB0aGF0IHRoZSBgZWNobyA9IEZBTFNFYCBwYXJhbWV0ZXIgd2FzIGFkZGVkIHRvIHRoZSBjb2RlIGNodW5rIHRvIHByZXZlbnQgcHJpbnRpbmcgb2YgdGhlIFIgY29kZSB0aGF0IGdlbmVyYXRlZCB0aGUgcGxvdC4NCg==