Teoria

La minería de datos 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 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 grafica o visual de los datos para su interpretación.Los métodos mas comunes son el analsis de sentimientos, La nube de palabras u el Top 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 regresiones

Instalar Paquetes y llamar librerias

#install.packages("tidyverse") # Manipulacion de datos
library(tidyverse)
#install.packages("tesseract") #OCR
library(tesseract)
#install.packages("magick") #PNG
library(magick)
#install.packages("officer") #PNG
library(officer)
#install.packages("pdftools") #PNG
library(pdftools)
#install.packages("purrr") #Para la funcion "map" para aplicar una funcion cada elemento de un vector
library(purrr)

Etapa 1: Obtener datos mediante OCR

De imagen PNG a texto

imagen1 <- image_read("C:\\Users\\Carlos\\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 en vlanco
doc1 <- doc1 %>% body_add_par(texto1) #Pega el texto en doc1
print(doc1,target = "texto1.docx") #Guardar el doc1 en la compu

Traduccion a español

imagen2 <- image_read("C:\\Users\\Carlos\\Downloads\\imagen2.PNG")
tesseract_download("spa")
## Training data already exists. Overwriting C:\Users\Carlos\AppData\Local\tesseract5\tesseract5\tessdata/spa.traineddata
## [1] "C:\\Users\\Carlos\\AppData\\Local\\tesseract5\\tesseract5\\tessdata/spa.traineddata"
texto2 <- ocr(imagen2)
texto2
## [1] "Un importante, y quiza controversial, asunto politico es el que se refiere al efecto del salario minimo 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 minimos.\n"
doc2 <- read_docx() #crea un documento en vlanco
doc2 <- doc2 %>% body_add_par(texto2) #Pega el texto en doc1
print(doc2,target = "texto2.docx") #Guardar el doc1 en la compu

Actividad 1. Eso

# Convertir PDF a imágenes y aplicar OCR
imagenes <- pdftools::pdf_convert("C:\\Users\\Carlos\\Downloads\\eso.pdf", dpi = 300)
## Converting page 1 to eso_1.png... done!
## Converting page 2 to eso_2.png... done!
texto3 <- map(imagenes, ocr)  # OCR a cada imagen

# Unir todas las páginas en un solo texto
texto_completo <- paste(texto3, collapse = "\n")

# Crear documento Word y agregar texto
doc3 <- read_docx() %>% 
  body_add_par(texto_completo)

# Guardar el documento
print(doc3, target = "C:\\Users\\Carlos\\Downloads\\texto3.docx")

Etapa.2 Explorar datos mediante Analisis de sentimientos

Instalar paquetes y llamar librerias

#install.packages("syuzhet") #Analsis de sentimientos
library(syuzhet)
#install.packages("tm")
library(tm)
#install.packages("wordcloud")
library(wordcloud)
#install.packages("RColorBrewer")
library(RColorBrewer)

Analisis de emociones y sentimientos

texto <- texto3
texto_palabras <- get_tokens(texto)
emociones <- get_nrc_sentiment (texto_palabras, language = "spanish")
barplot(colSums(prop.table(emociones[,1:8])))

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

## 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

LS0tDQp0aXRsZTogIk1pbmVyaWEgZGUgZGF0b3MiDQphdXRob3I6ICJEYXJpbyBHYWxsYXJkbyINCmRhdGU6ICIyMDI1LTAyLTE3Ig0Kb3V0cHV0Og0KICBodG1sX2RvY3VtZW50Og0KICAgIHRvYzogVFJVRQ0KICAgIHRvY19mbG9hdDogVFJVRQ0KICAgIGNvZGVfZG93bmxvYWQ6IFRSVUUNCiAgICB0aGVtZTogY29zbW8NCi0tLQ0KDQohW10oQzpcVXNlcnNcQ2FybG9zXERvY3VtZW50c1xJVC5wbmcpDQoNCiMgPHNwYW4gc3R5bGU9ImNvbG9yOiByZWQ7Ij5UZW9yaWE8L3NwYW4+DQpMYSAqKm1pbmVyw61hIGRlIGRhdG9zIGRlIHRleHRvIChUTSkqKiBlcyBlbCBwcm9jZXNvIGRlIGV4dHJhZXIgaW5mb3JtYWNpw7NuIMO6dGlsLCBwYXRyb25lcyBvIGNvbm9jaW1pZW50b3MgZGUgdGV4dG9zIG5vIGVzdHJ1Y3R1cmFkb3MNCg0KDQpDb25zdGEgZGUgdHJlcyBldGFwYXM6ICANCg0KMS4gT2J0ZW5lciBkYXRvczogRWwgKipSZWNvbm9jaW1pZW50byBPcHRpY28gZGUgY2FyYWN0ZXJlcyAoT0NSKSoqIGVzIHVuYSB0ZWNub2xvZ8OtYSBxdWUgcGVybWl0ZSBjb252ZXJ0aXIgaW3DoWdlbmVzIGRlIHRleHRvIGVuIHRleHRvIGVkaXRhYmxlLiBUYW1iacOpbiBlcyBjb25vY2lkbyBjb21vICoqRXh0cmFjY2nDs24gZGUgdGV4dG8gZGUgaW3DoWdlbmVzLioqICANCg0KMi4gRXhwbG9yYXIgZGF0b3M6ICBSZXByZXNlbnRhY2nDs24gZ3JhZmljYSBvIHZpc3VhbCBkZSBsb3MgZGF0b3MgcGFyYSBzdSBpbnRlcnByZXRhY2nDs24uTG9zIG3DqXRvZG9zIG1hcyBjb211bmVzIHNvbiBlbCBhbmFsc2lzIGRlIHNlbnRpbWllbnRvcywgTGEgbnViZSBkZSBwYWxhYnJhcyB1IGVsIFRvcCBtb2RlbGluZyAgfQ0KDQozLiBBbsOhbGlzaXMgcHJlZGljdGl2bzogU29uIGxhcyB0w6ljbmljYXMgeSBtb2RlbG9zIGVzdGFkw61zdGljb3MgcGFyYSBwcmVkZWNpciByZXN1bHRhZG9zIGZ1dHVyb3MuIExvcyBtb2RlbG9zIG3DoXMgdXNhZG9zIHNvbiBlbCByYW5kb20gZm9yZXN0LCByZWRlcyBuZXVyb25hbGVzIHkgcmVncmVzaW9uZXMNCg0KDQojIDxzcGFuIHN0eWxlPSJjb2xvcjogcmVkOyI+SW5zdGFsYXIgUGFxdWV0ZXMgeSBsbGFtYXIgbGlicmVyaWFzPC9zcGFuPg0KYGBge3IgbWVzc2FnZT1GQUxTRSwgd2FybmluZz1GQUxTRX0NCiNpbnN0YWxsLnBhY2thZ2VzKCJ0aWR5dmVyc2UiKSAjIE1hbmlwdWxhY2lvbiBkZSBkYXRvcw0KbGlicmFyeSh0aWR5dmVyc2UpDQojaW5zdGFsbC5wYWNrYWdlcygidGVzc2VyYWN0IikgI09DUg0KbGlicmFyeSh0ZXNzZXJhY3QpDQojaW5zdGFsbC5wYWNrYWdlcygibWFnaWNrIikgI1BORw0KbGlicmFyeShtYWdpY2spDQojaW5zdGFsbC5wYWNrYWdlcygib2ZmaWNlciIpICNQTkcNCmxpYnJhcnkob2ZmaWNlcikNCiNpbnN0YWxsLnBhY2thZ2VzKCJwZGZ0b29scyIpICNQTkcNCmxpYnJhcnkocGRmdG9vbHMpDQojaW5zdGFsbC5wYWNrYWdlcygicHVycnIiKSAjUGFyYSBsYSBmdW5jaW9uICJtYXAiIHBhcmEgYXBsaWNhciB1bmEgZnVuY2lvbiBjYWRhIGVsZW1lbnRvIGRlIHVuIHZlY3Rvcg0KbGlicmFyeShwdXJycikNCmBgYA0KIyA8c3BhbiBzdHlsZT0iY29sb3I6IHJlZDsiPkV0YXBhIDE6IE9idGVuZXIgZGF0b3MgbWVkaWFudGUgT0NSPC9zcGFuPg0KDQojIyA8c3BhbiBzdHlsZT0iY29sb3I6IHJlZDsiPkRlIGltYWdlbiBQTkcgYSB0ZXh0bzwvc3Bhbj4NCmBgYHtyfQ0KaW1hZ2VuMSA8LSBpbWFnZV9yZWFkKCJDOlxcVXNlcnNcXENhcmxvc1xcRG93bmxvYWRzXFxpbWFnZW4xLlBORyIpDQp0ZXh0bzEgPC0gb2NyKGltYWdlbjEpDQp0ZXh0bzENCmRvYzEgPC0gcmVhZF9kb2N4KCkgI2NyZWEgdW4gZG9jdW1lbnRvIGVuIHZsYW5jbw0KZG9jMSA8LSBkb2MxICU+JSBib2R5X2FkZF9wYXIodGV4dG8xKSAjUGVnYSBlbCB0ZXh0byBlbiBkb2MxDQpwcmludChkb2MxLHRhcmdldCA9ICJ0ZXh0bzEuZG9jeCIpICNHdWFyZGFyIGVsIGRvYzEgZW4gbGEgY29tcHUNCmBgYA0KIyMgPHNwYW4gc3R5bGU9ImNvbG9yOiByZWQ7Ij5UcmFkdWNjaW9uIGEgZXNwYcOxb2w8L3NwYW4+DQpgYGB7cn0NCmltYWdlbjIgPC0gaW1hZ2VfcmVhZCgiQzpcXFVzZXJzXFxDYXJsb3NcXERvd25sb2Fkc1xcaW1hZ2VuMi5QTkciKQ0KdGVzc2VyYWN0X2Rvd25sb2FkKCJzcGEiKQ0KdGV4dG8yIDwtIG9jcihpbWFnZW4yKQ0KdGV4dG8yDQpkb2MyIDwtIHJlYWRfZG9jeCgpICNjcmVhIHVuIGRvY3VtZW50byBlbiB2bGFuY28NCmRvYzIgPC0gZG9jMiAlPiUgYm9keV9hZGRfcGFyKHRleHRvMikgI1BlZ2EgZWwgdGV4dG8gZW4gZG9jMQ0KcHJpbnQoZG9jMix0YXJnZXQgPSAidGV4dG8yLmRvY3giKSAjR3VhcmRhciBlbCBkb2MxIGVuIGxhIGNvbXB1DQpgYGANCiMjIDxzcGFuIHN0eWxlPSJjb2xvcjogcmVkOyI+QWN0aXZpZGFkIDEuIEVzbzwvc3Bhbj4NCmBgYHtyfQ0KIyBDb252ZXJ0aXIgUERGIGEgaW3DoWdlbmVzIHkgYXBsaWNhciBPQ1INCmltYWdlbmVzIDwtIHBkZnRvb2xzOjpwZGZfY29udmVydCgiQzpcXFVzZXJzXFxDYXJsb3NcXERvd25sb2Fkc1xcZXNvLnBkZiIsIGRwaSA9IDMwMCkNCnRleHRvMyA8LSBtYXAoaW1hZ2VuZXMsIG9jcikgICMgT0NSIGEgY2FkYSBpbWFnZW4NCg0KIyBVbmlyIHRvZGFzIGxhcyBww6FnaW5hcyBlbiB1biBzb2xvIHRleHRvDQp0ZXh0b19jb21wbGV0byA8LSBwYXN0ZSh0ZXh0bzMsIGNvbGxhcHNlID0gIlxuIikNCg0KIyBDcmVhciBkb2N1bWVudG8gV29yZCB5IGFncmVnYXIgdGV4dG8NCmRvYzMgPC0gcmVhZF9kb2N4KCkgJT4lIA0KICBib2R5X2FkZF9wYXIodGV4dG9fY29tcGxldG8pDQoNCiMgR3VhcmRhciBlbCBkb2N1bWVudG8NCnByaW50KGRvYzMsIHRhcmdldCA9ICJDOlxcVXNlcnNcXENhcmxvc1xcRG93bmxvYWRzXFx0ZXh0bzMuZG9jeCIpDQoNCmBgYA0KIyA8c3BhbiBzdHlsZT0iY29sb3I6IHJlZDsiPkV0YXBhLjIgRXhwbG9yYXIgZGF0b3MgbWVkaWFudGUgQW5hbGlzaXMgZGUgc2VudGltaWVudG9zPC9zcGFuPiAgDQoNCiMjIDxzcGFuIHN0eWxlPSJjb2xvcjogcmVkOyI+SW5zdGFsYXIgcGFxdWV0ZXMgeSBsbGFtYXIgbGlicmVyaWFzPC9zcGFuPg0KYGBge3IgbWVzc2FnZT1GQUxTRSwgd2FybmluZz1GQUxTRX0NCiNpbnN0YWxsLnBhY2thZ2VzKCJzeXV6aGV0IikgI0FuYWxzaXMgZGUgc2VudGltaWVudG9zDQpsaWJyYXJ5KHN5dXpoZXQpDQojaW5zdGFsbC5wYWNrYWdlcygidG0iKQ0KbGlicmFyeSh0bSkNCiNpbnN0YWxsLnBhY2thZ2VzKCJ3b3JkY2xvdWQiKQ0KbGlicmFyeSh3b3JkY2xvdWQpDQojaW5zdGFsbC5wYWNrYWdlcygiUkNvbG9yQnJld2VyIikNCmxpYnJhcnkoUkNvbG9yQnJld2VyKQ0KYGBgDQojIyA8c3BhbiBzdHlsZT0iY29sb3I6IHJlZDsiPkFuYWxpc2lzIGRlIGVtb2Npb25lcyB5IHNlbnRpbWllbnRvczwvc3Bhbj4NCmBgYHtyfQ0KdGV4dG8gPC0gdGV4dG8zDQp0ZXh0b19wYWxhYnJhcyA8LSBnZXRfdG9rZW5zKHRleHRvKQ0KZW1vY2lvbmVzIDwtIGdldF9ucmNfc2VudGltZW50ICh0ZXh0b19wYWxhYnJhcywgbGFuZ3VhZ2UgPSAic3BhbmlzaCIpDQpiYXJwbG90KGNvbFN1bXMocHJvcC50YWJsZShlbW9jaW9uZXNbLDE6OF0pKSkNCnNlbnRpbWllbnRvIDwtIChlbW9jaW9uZXMkbmVnYXRpdmUqLTEpK2Vtb2Npb25lcyRwb3NpdGl2ZQ0Kc2ltcGxlX3Bsb3Qoc2VudGltaWVudG8pDQpgYGANCiMjIDxzcGFuIHN0eWxlPSJjb2xvcjogcmVkOyI+TnViZSBkZSBwYWxhYnJhczwvc3Bhbj4NCmBgYHtyfQ0KcGFsYWJyYXMgPC0gdGV4dG9fcGFsYWJyYXMNCnBhbGFicmFzIDwtIHJlbW92ZVdvcmRzKHBhbGFicmFzLGMoc3RvcHdvcmRzKCJzcGFuaXNoIiksImhhY2lhIiwiaGFiaWEiLCJoYWJpYW4iLCJoZWNobyIpKQ0Kd29yZGNsb3VkKHdvcmRzPXBhbGFicmFzLCBtaW4uZnJlcT0yLHJvdC5wZXIgPSAwLCByYW5kb20ub3JkZXIgPSBGQUxTRSkNCmBgYA0KDQoNCg0KDQoNCg0KDQoNCg0KDQoNCg==