
Teoría
El Reconocimiento Óptico de Caracteres (OCR) es una
tecnología utilizada para convertir diferentes tipos de documentos, como
imágenes, documentos impresos, fotografías de texto, archivos PDF o
imágenes capturadas con una cámara, en datos editables y buscables.
La Minería de Datos(TM) es el proceso de extraer
información útil, patrones o conocimiento de textos no
estructurados.
Consta de 3 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ágnes.
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 Modelling.
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 librerías
# install.packages("tidyverse") # Manipulación de datos"
library(tidyverse)
# install.packages("tesseract") # OCR
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 una función a cada elemento de un vector
library(purrr)
# install.packages("syuzhet") #Análisis de sentimientos
library(syuzhet)
# install.packages("tm") # Míneria de Texto
library(tm)
# install.packages("wordcloud") # Nube de Palabras
library(wordcloud)
# install.packages("RColorBrewer") # Colores
library(RColorBrewer)
De imagen PNG a texto en Word
imagen1 <- image_read("C:\\Users\\Adrián\\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 documento de word en blanco
doc1 <- doc1 %>% body_add_par(texto1) # Pega texto en el documento
# print(doc1, target="texto1.docx") # Guarda el documento en la computadora
De imagen PNG en Español a texto en Word
imagen2 <- image_read("C:\\Users\\Adrián\\Downloads\\imagen2.PNG")
tesseract_download("spa")
## Training data already exists. Overwriting C:\Users\Adrián\AppData\Local\tesseract5\tesseract5\tessdata/spa.traineddata
## [1] "C:\\Users\\Adrián\\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()
doc2 <- doc2 %>% body_add_par(texto2)
print(doc2, target="texto2.docx")
De PDF a texto en Word
pdf_eso <- pdf_convert("C:\\Users\\Adrián\\Downloads\\eso.pdf") %>% 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
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"),"habia","hacia","casi"))
wordcloud(words=palabras,min.freq=2,rot.per=0,random.order = FALSE)

Conclusiones
Mediante el uso de “OCR”, así como el “Análisis de
Sentimientos” y la “Nube de Palabras”, es posible digitalizar, analizar
y detectar los aspectos más relevantes dentro de un documento o archivo
de texto de forma rápida y eficiente, sin la necesidad de leer el texto
de forma completa o de requerir insertar de forma manual el texto a
analizar.
LS0tDQp0aXRsZTogIk9DUiINCmF1dGhvcjogIkx1aXMgRMOhdmlsYSAtIEEwMTI4NTUyMSINCmRhdGU6ICIyMDI1LTA4LTIwIg0Kb3V0cHV0Og0KICBodG1sX2RvY3VtZW50Og0KICAgIHRvYzogVFJVRQ0KICAgIHRvY19mbG9hdDogVFJVRQ0KICAgIGNvZGVfZG93bmxvYWQ6IFRSVUUNCiAgICB0aGVtZTogc2ltcGxleA0KLS0tDQoNCiFbXShodHRwczovL2Nkbi5wcm9kLndlYnNpdGUtZmlsZXMuY29tLzYxZTdkMjU5Yjc3NDZlM2Y2M2YwYjZiZS82MmRmZjYyMWZmNjk3NmI0MDE2MTE2NDJfU2FucyUyMHRpdHJlJTIwKDIwKS5wbmcpICAgICANCg0KIyA8c3BhbiBzdHlsZT0iY29sb3I6cmVkOyI+IFRlb3LDrWEgPC9zcGFuPiAgICANCkVsICoqUmVjb25vY2ltaWVudG8gw5NwdGljbyBkZSBDYXJhY3RlcmVzIChPQ1IpKiogZXMgdW5hIHRlY25vbG9nw61hIHV0aWxpemFkYSBwYXJhIGNvbnZlcnRpciBkaWZlcmVudGVzIHRpcG9zIGRlIGRvY3VtZW50b3MsIGNvbW8gaW3DoWdlbmVzLCBkb2N1bWVudG9zIGltcHJlc29zLCBmb3RvZ3JhZsOtYXMgZGUgdGV4dG8sIGFyY2hpdm9zIFBERiBvIGltw6FnZW5lcyBjYXB0dXJhZGFzIGNvbiB1bmEgY8OhbWFyYSwgZW4gZGF0b3MgZWRpdGFibGVzIHkgYnVzY2FibGVzLiAgICANCg0KTGEgKipNaW5lcsOtYSBkZSBEYXRvcyhUTSkqKiBlcyBlbCBwcm9jZXNvIGRlIGV4dHJhZXIgaW5mb3JtYWNpw7NuIMO6dGlsLCBwYXRyb25lcyBvIGNvbm9jaW1pZW50byBkZSB0ZXh0b3Mgbm8gZXN0cnVjdHVyYWRvcy4gICANCg0KQ29uc3RhIGRlIDMgRXRhcGFzOiAgIA0KMS4gT2J0ZW5lciBkYXRvczogRWwgUmVjb25vY2ltaWVudG8gw5NwdGljbyBkZSBDYXJhY3RlcmVzIChPQ1IpLCBlcyB1bmEgdGVjbm9sb2fDrWEgcXVlIHBlcm1pdGUgY29udmVydGlyIGltw6FnZW5lcyBkZSB0ZXh0byBlbiB0ZXh0byBlZGl0YWJsZS4gVGFtYmnDqW4gZXMgY29ub2NpZG8gY29tbyBleHRyYWNjacOzbiBkZSB0ZXh0byBkZSBpbcOhZ25lcy4gICAgDQoyLiBFeHBsb3JhciBkYXRvczogUmVwcmVzZW50YWNpw7NuIGdyw6FmaWNhIG8gdmlzdWFsIGRlIGxvcyBkYXRvcyBwYXJhIHN1IGludGVycHJldGFjacOzbi4gTG9zIG3DqXRvZG9zIG3DoXMgY29tdW5lcyBzb24gZWwgQW7DoWxpc2lzIGRlIFNlbnRpbWllbnRvcywgbGEgTnViZSBkZSBQYWxhYnJhcyB5IGVsIFRvcGljIE1vZGVsbGluZy4gICAgDQozLiBBbsOhbGlzaXMgcHJlZGljdGl2bzogU29uIGxhcyB0w6ljbmljYXMgeSBtb2RlbG9zIGVzdGFkw61zdGljb3MgcGFyYSBwcmVkZWNpciByZXN1bHRhZG9zIGZ1dHVyb3MuIExvcyBtb2RlbG9zIG3DoXMgdXNhZG9zIHNvbiBlbCBSYW5kb20gRm9yZXN0LCByZWRlcyBuZXVyb25hbGVzIHkgcmVncmVzaW9uZXMuICAgICANCg0KIyA8c3BhbiBzdHlsZT0iY29sb3I6cmVkOyI+IEluc3RhbGFyIHBhcXVldGVzIHkgbGxhbWFyIGxpYnJlcsOtYXMgPC9zcGFuPiAgICANCmBgYHtyIG1lc3NhZ2U9RkFMU0UsIHdhcm5pbmc9RkFMU0V9DQojIGluc3RhbGwucGFja2FnZXMoInRpZHl2ZXJzZSIpICMgTWFuaXB1bGFjacOzbiBkZSBkYXRvcyINCmxpYnJhcnkodGlkeXZlcnNlKQ0KIyBpbnN0YWxsLnBhY2thZ2VzKCJ0ZXNzZXJhY3QiKSAjIE9DUg0KbGlicmFyeSh0ZXNzZXJhY3QpDQojIGluc3RhbGwucGFja2FnZXMoIm1hZ2ljayIpICMgUE5HDQpsaWJyYXJ5KG1hZ2ljaykNCiMgaW5zdGFsbC5wYWNrYWdlcygib2ZmaWNlciIpICMgT2ZmaWNlIFdvcmQNCmxpYnJhcnkob2ZmaWNlcikNCiMgaW5zdGFsbC5wYWNrYWdlcygicGRmdG9vbHMiKSAjIFBERg0KbGlicmFyeShwZGZ0b29scykNCiMgaW5zdGFsbC5wYWNrYWdlcygicHVycnIiKSAjIFBhcmEgbGEgZnVuY2nDs24gIm1hcCIgcGFyYSBhcGxpY2FyIHVuYSBmdW5jacOzbiBhIGNhZGEgZWxlbWVudG8gZGUgdW4gdmVjdG9yDQpsaWJyYXJ5KHB1cnJyKQ0KIyBpbnN0YWxsLnBhY2thZ2VzKCJzeXV6aGV0IikgI0Fuw6FsaXNpcyBkZSBzZW50aW1pZW50b3MNCmxpYnJhcnkoc3l1emhldCkNCiMgaW5zdGFsbC5wYWNrYWdlcygidG0iKSAjIE3DrW5lcmlhIGRlIFRleHRvDQpsaWJyYXJ5KHRtKQ0KIyBpbnN0YWxsLnBhY2thZ2VzKCJ3b3JkY2xvdWQiKSAjIE51YmUgZGUgUGFsYWJyYXMNCmxpYnJhcnkod29yZGNsb3VkKQ0KIyBpbnN0YWxsLnBhY2thZ2VzKCJSQ29sb3JCcmV3ZXIiKSAjIENvbG9yZXMNCmxpYnJhcnkoUkNvbG9yQnJld2VyKQ0KYGBgDQoNCiMgPHNwYW4gc3R5bGU9ImNvbG9yOnJlZDsiPiBEZSBpbWFnZW4gUE5HIGEgdGV4dG8gZW4gV29yZCA8L3NwYW4+ICAgICAgDQpgYGB7cn0NCmltYWdlbjEgPC0gaW1hZ2VfcmVhZCgiQzpcXFVzZXJzXFxBZHJpw6FuXFxEb3dubG9hZHNcXGltYWdlbjEuUE5HIikNCnRleHRvMSA8LSBvY3IoaW1hZ2VuMSkNCnRleHRvMQ0KZG9jMSA8LSByZWFkX2RvY3goKSAjIENyZWEgZG9jdW1lbnRvIGRlIHdvcmQgZW4gYmxhbmNvDQpkb2MxIDwtIGRvYzEgJT4lIGJvZHlfYWRkX3Bhcih0ZXh0bzEpICMgUGVnYSB0ZXh0byBlbiBlbCBkb2N1bWVudG8NCiMgcHJpbnQoZG9jMSwgdGFyZ2V0PSJ0ZXh0bzEuZG9jeCIpICMgR3VhcmRhIGVsIGRvY3VtZW50byBlbiBsYSBjb21wdXRhZG9yYQ0KYGBgDQojIDxzcGFuIHN0eWxlPSJjb2xvcjpyZWQ7Ij4gRGUgaW1hZ2VuIFBORyBlbiBFc3Bhw7FvbCBhIHRleHRvIGVuIFdvcmQgPC9zcGFuPiAgICANCmBgYHtyfQ0KaW1hZ2VuMiA8LSBpbWFnZV9yZWFkKCJDOlxcVXNlcnNcXEFkcmnDoW5cXERvd25sb2Fkc1xcaW1hZ2VuMi5QTkciKQ0KdGVzc2VyYWN0X2Rvd25sb2FkKCJzcGEiKQ0KdGV4dG8yIDwtIG9jcihpbWFnZW4yLCBlbmdpbmUgPSB0ZXNzZXJhY3QoInNwYSIpKQ0KdGV4dG8yDQpkb2MyIDwtIHJlYWRfZG9jeCgpDQpkb2MyIDwtIGRvYzIgJT4lIGJvZHlfYWRkX3Bhcih0ZXh0bzIpDQpwcmludChkb2MyLCB0YXJnZXQ9InRleHRvMi5kb2N4IikNCmBgYA0KDQojIDxzcGFuIHN0eWxlPSJjb2xvcjpyZWQ7Ij4gRGUgUERGIGEgdGV4dG8gZW4gV29yZCA8L3NwYW4+ICAgICAgDQpgYGB7cn0NCnBkZl9lc28gPC0gcGRmX2NvbnZlcnQoIkM6XFxVc2Vyc1xcQWRyacOhblxcRG93bmxvYWRzXFxlc28ucGRmIikgJT4lIG1hcChvY3IpDQojIFJlcGV0aXIgcGFzb3MgcHJldmlvcyBwYXJhIGNvbnZlcnRpciBpbcOhZ2VuZXMgYSB0ZXh0byBlbiBXb3JkDQpgYGANCiMgPHNwYW4gc3R5bGU9ImNvbG9yOnJlZDsiPiBBbsOhbGlzaXMgZGUgRW1vY2lvbmVzIHkgU2VudGltaWVudG9zIDwvc3Bhbj4gICAgIA0KYGBge3J9DQp0ZXh0byA8LSBwZGZfZXNvIA0KdGV4dG9fcGFsYWJyYXMgPC0gZ2V0X3Rva2Vucyh0ZXh0bykNCmVtb2Npb25lcyA8LSBnZXRfbnJjX3NlbnRpbWVudCh0ZXh0b19wYWxhYnJhcywgbGFuZ3VhZ2UgPSAic3BhbmlzaCIpDQojIEFsZWdyw61hLCBUcmlzdGV6YSwgSXJhLCBNaWVkbywgU29ycHJlc2EsIEFzY28sIEFudGljaXBhY2nDs24sIENvbmZpYW56YQ0KYmFycGxvdChjb2xTdW1zKHByb3AudGFibGUoZW1vY2lvbmVzWywxOjhdKSkpDQpzZW50aW1pZW50b3MgPC0gKGVtb2Npb25lcyRuZWdhdGl2ZSotMSkrZW1vY2lvbmVzJHBvc2l0aXZlDQpzaW1wbGVfcGxvdChzZW50aW1pZW50b3MpDQpgYGANCg0KIyA8c3BhbiBzdHlsZT0iY29sb3I6cmVkIj4gTnViZSBkZSBQYWxhYnJhcyA8L3NwYW4+ICAgIA0KYGBge3Igd2FybmluZz1GQUxTRX0NCnBhbGFicmFzIDwtIHRleHRvX3BhbGFicmFzDQpwYWxhYnJhcyA8LSByZW1vdmVXb3JkcyhwYWxhYnJhcywgYyhzdG9wd29yZHMoInNwYW5pc2giKSwiaGFiaWEiLCJoYWNpYSIsImNhc2kiKSkNCndvcmRjbG91ZCh3b3Jkcz1wYWxhYnJhcyxtaW4uZnJlcT0yLHJvdC5wZXI9MCxyYW5kb20ub3JkZXIgPSBGQUxTRSkNCmBgYA0KDQojIDxzcGFuIHN0eWxlPSJjb2xvcjpyZWQiPiBDb25jbHVzaW9uZXMgPC9zcGFuPiAgICAgICAgICANCk1lZGlhbnRlIGVsIHVzbyBkZSAqIk9DUiIqLCBhc8OtIGNvbW8gZWwgIkFuw6FsaXNpcyBkZSBTZW50aW1pZW50b3MiIHkgbGEgIk51YmUgZGUgUGFsYWJyYXMiLCBlcyBwb3NpYmxlIGRpZ2l0YWxpemFyLCBhbmFsaXphciB5IGRldGVjdGFyIGxvcyBhc3BlY3RvcyBtw6FzIHJlbGV2YW50ZXMgZGVudHJvIGRlIHVuIGRvY3VtZW50byBvIGFyY2hpdm8gZGUgdGV4dG8gZGUgZm9ybWEgcsOhcGlkYSB5IGVmaWNpZW50ZSwgc2luIGxhIG5lY2VzaWRhZCBkZSBsZWVyIGVsIHRleHRvIGRlIGZvcm1hIGNvbXBsZXRhIG8gZGUgcmVxdWVyaXIgaW5zZXJ0YXIgZGUgZm9ybWEgbWFudWFsIGVsIHRleHRvIGEgYW5hbGl6YXIuICAgDQo=