Teoría
El Reconomicieminto Óptico de Caracteres (OCR) es
una tecnología utilizada para convertir diferentes tipos de documentos,
como imágenes, documentos impresos escaneados, fotografías de texto,
archivos PDF o imágenes capturadas con una cámara en datos editables y
buscables
La Minerías de Datos (TM) es el proceso de extraer
información útil, patrones o conocimiento de textos no
estructurados.
Consta de 3 étapas: 1. Obtener Datos: El Reconocimiento Óptico de
Caracteres (OCR), es una tecnología que permite convertir imágenes de
texto editable. También es conocido como extracción de texto a imágenes.
2. Explorar datos: Representación gráfica o visual de los datos para su
interpretración. Los métodos más comunes 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 utilizados son el Random Forest, redes nueronales y
regresiones.
Installar y llamar librerías
#install.packages("tidyverse")
#install.packages("tesseract")
#install.packages("magick")
#install.packages("officer")
#install.packages("pdftools")
#install.packages("purr")
#install.packages("syuzhet")
#install.packages("tm")
#install.packages("wordcloud")
#install.packages("RColorBrewer")
library(tidyverse)
library(tesseract)
library(magick)
library(officer)
library(pdftools)
library(purrr)
library(syuzhet)
library(tm)
library(wordcloud)
library(RColorBrewer)
De imágen PNG a texto en Word
imagen1 <- image_read("C:\\Users\\erik-\\OneDrive\\Documentos\\Escuela\\Universidad\\7ºSemestre\\Modulo_2\\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()
doc1 <- doc1 %>% body_add_par(texto1)
print(doc1, target = "texto1.docx")
De imágen PNG en Español a texto en Word
imagen2 <- image_read("C:\\Users\\erik-\\OneDrive\\Documentos\\Escuela\\Universidad\\7ºSemestre\\Modulo_2\\imagen2.PNG")
tesseract_download("spa")
## [1] "C:\\Users\\erik-\\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 Word
pdf_eso <- pdf_convert("C:\\Users\\erik-\\OneDrive\\Documentos\\Escuela\\Universidad\\7ºSemestre\\Modulo_2\\eso.pdf") %>% map(ocr)
## Converting page 1 to eso_1.png... done!
## Converting page 2 to eso_2.png... done!
Análisis de Emociones y Sentimientos
texto <- pdf_eso
texto_palabras <- get_tokens(texto)
emociones <- get_nrc_sentiment(texto_palabras, language = "spanish")
sentimientos <- (emociones$negative * -1) + emociones$positive
simple_plot(sentimientos)

LS0tDQp0aXRsZTogIk9DUiINCmF1dGhvcjogIkVyaWsgR29uemFsZXoiDQpkYXRlOiAiMjAyNS0wOC0yMCINCm91dHB1dDoNCiAgaHRtbF9kb2N1bWVudDoNCiAgICB0b2M6IFRSVUUNCiAgICB0b2NfZmxvYXQ6IFRydWUgDQogICAgY29kZV9kb3dubG9hZDogVFJVRQ0KICAgIHRoZW1lOiBzaW1wbGV4DQotLS0NCg0KDQoNCiMgPHNwYW4gc3R5bGUgPSAiY29sb3I6cmVkOyI+IFRlb3LDrWEgPC9zcGFuPg0KRWwgKipSZWNvbm9taWNpZW1pbnRvIMOTcHRpY28gZGUgQ2FyYWN0ZXJlcyAoT0NSKSoqIGVzIHVuYSB0ZWNub2xvZ8OtYSB1dGlsaXphZGEgcGFyYSBjb252ZXJ0aXIgZGlmZXJlbnRlcyB0aXBvcyBkZSBkb2N1bWVudG9zLCBjb21vIGltw6FnZW5lcywgZG9jdW1lbnRvcyBpbXByZXNvcyBlc2NhbmVhZG9zLCBmb3RvZ3JhZsOtYXMgZGUgdGV4dG8sIGFyY2hpdm9zIFBERiBvIGltw6FnZW5lcyBjYXB0dXJhZGFzIGNvbiB1bmEgY8OhbWFyYSBlbiBkYXRvcyBlZGl0YWJsZXMgeSBidXNjYWJsZXMNCg0KTGEgKipNaW5lcsOtYXMgZGUgRGF0b3MgKFRNKSoqIGVzIGVsIHByb2Nlc28gZGUgZXh0cmFlciBpbmZvcm1hY2nDs24gw7p0aWwsIHBhdHJvbmVzIG8gY29ub2NpbWllbnRvIGRlIHRleHRvcyBubyBlc3RydWN0dXJhZG9zLiANCg0KQ29uc3RhIGRlIDMgw6l0YXBhczoNCjEuIE9idGVuZXIgRGF0b3M6IEVsIFJlY29ub2NpbWllbnRvIMOTcHRpY28gZGUgQ2FyYWN0ZXJlcyAoT0NSKSwgZXMgdW5hIHRlY25vbG9nw61hIHF1ZSBwZXJtaXRlIGNvbnZlcnRpciBpbcOhZ2VuZXMgZGUgdGV4dG8gZWRpdGFibGUuIFRhbWJpw6luIGVzIGNvbm9jaWRvIGNvbW8gZXh0cmFjY2nDs24gZGUgdGV4dG8gYSBpbcOhZ2VuZXMuIA0KMi4gRXhwbG9yYXIgZGF0b3M6IFJlcHJlc2VudGFjacOzbiBncsOhZmljYSBvIHZpc3VhbCBkZSBsb3MgZGF0b3MgcGFyYSBzdSBpbnRlcnByZXRyYWNpw7NuLiBMb3MgbcOpdG9kb3MgbcOhcyBjb211bmVzIGVsIEFuw6FsaXNpcyBkZSBTZW50aW1pZW50b3MsIGxhIE51YmUgZGUgUGFsYWJyYXMgeSBlbCBUb3BpYyBNb2RlbGluZy4NCjMuIEFuw6FsaXNpcyBwcmVkaWN0aXZvOiBTb24gbGFzIHTDqWNuaWNhcyB5IG1vZGVsb3MgZXN0YWTDrXN0aWNvcyBwYXJhIHByZWRlY2lyIHJlc3VsdGFkb3MgZnV0dXJvcy4gTG9zIG1vZGVsb3MgbcOhcyB1dGlsaXphZG9zIHNvbiBlbCBSYW5kb20gRm9yZXN0LCByZWRlcyBudWVyb25hbGVzIHkgcmVncmVzaW9uZXMuIA0KDQoNCiMgPHNwYW4gc3R5bGUgPSAiY29sb3I6cmVkOyI+IEluc3RhbGxhciB5IGxsYW1hciBsaWJyZXLDrWFzIDwvc3Bhbj4NCmBgYHtyIG1lc3NhZ2U9RkFMU0UsIHdhcm5pbmc9RkFMU0V9DQojaW5zdGFsbC5wYWNrYWdlcygidGlkeXZlcnNlIikNCiNpbnN0YWxsLnBhY2thZ2VzKCJ0ZXNzZXJhY3QiKQ0KI2luc3RhbGwucGFja2FnZXMoIm1hZ2ljayIpDQojaW5zdGFsbC5wYWNrYWdlcygib2ZmaWNlciIpDQojaW5zdGFsbC5wYWNrYWdlcygicGRmdG9vbHMiKQ0KI2luc3RhbGwucGFja2FnZXMoInB1cnIiKQ0KI2luc3RhbGwucGFja2FnZXMoInN5dXpoZXQiKQ0KI2luc3RhbGwucGFja2FnZXMoInRtIikNCiNpbnN0YWxsLnBhY2thZ2VzKCJ3b3JkY2xvdWQiKQ0KI2luc3RhbGwucGFja2FnZXMoIlJDb2xvckJyZXdlciIpDQoNCmxpYnJhcnkodGlkeXZlcnNlKQ0KbGlicmFyeSh0ZXNzZXJhY3QpDQpsaWJyYXJ5KG1hZ2ljaykNCmxpYnJhcnkob2ZmaWNlcikNCmxpYnJhcnkocGRmdG9vbHMpDQpsaWJyYXJ5KHB1cnJyKQ0KbGlicmFyeShzeXV6aGV0KQ0KbGlicmFyeSh0bSkNCmxpYnJhcnkod29yZGNsb3VkKQ0KbGlicmFyeShSQ29sb3JCcmV3ZXIpDQpgYGANCg0KDQojIDxzcGFuIHN0eWxlID0gImNvbG9yOnJlZDsiPiBEZSBpbcOhZ2VuIFBORyBhIHRleHRvIGVuIFdvcmQgPC9zcGFuPg0KYGBge3IgbWVzc2FnZT1GQUxTRSwgd2FybmluZz1GQUxTRX0NCmltYWdlbjEgPC0gaW1hZ2VfcmVhZCgiQzpcXFVzZXJzXFxlcmlrLVxcT25lRHJpdmVcXERvY3VtZW50b3NcXEVzY3VlbGFcXFVuaXZlcnNpZGFkXFw3wrpTZW1lc3RyZVxcTW9kdWxvXzJcXGltYWdlbjEuUE5HIikNCg0KDQp0ZXh0bzEgPC0gb2NyKGltYWdlbjEpDQp0ZXh0bzENCmRvYzEgPC0gcmVhZF9kb2N4KCkNCmRvYzEgPC0gZG9jMSAlPiUgYm9keV9hZGRfcGFyKHRleHRvMSkNCnByaW50KGRvYzEsIHRhcmdldCA9ICJ0ZXh0bzEuZG9jeCIpDQpgYGANCg0KDQojIDxzcGFuIHN0eWxlID0gImNvbG9yOnJlZDsiPiBEZSBpbcOhZ2VuIFBORyBlbiBFc3Bhw7FvbCBhIHRleHRvIGVuIFdvcmQgPC9zcGFuPg0KYGBge3IgbWVzc2FnZT1GQUxTRSwgd2FybmluZz1GQUxTRX0NCmltYWdlbjIgPC0gaW1hZ2VfcmVhZCgiQzpcXFVzZXJzXFxlcmlrLVxcT25lRHJpdmVcXERvY3VtZW50b3NcXEVzY3VlbGFcXFVuaXZlcnNpZGFkXFw3wrpTZW1lc3RyZVxcTW9kdWxvXzJcXGltYWdlbjIuUE5HIikNCnRlc3NlcmFjdF9kb3dubG9hZCgic3BhIikNCg0KdGV4dG8yIDwtIG9jcihpbWFnZW4yLCBlbmdpbmUgPSB0ZXNzZXJhY3QoInNwYSIpKQ0KdGV4dG8yDQpkb2MyIDwtIHJlYWRfZG9jeCgpDQpkb2MyIDwtIGRvYzIgJT4lIGJvZHlfYWRkX3Bhcih0ZXh0bzIpDQpwcmludChkb2MyLCB0YXJnZXQgPSAidGV4dG8yLmRvY3giKQ0KYGBgDQoNCiMgPHNwYW4gc3R5bGUgPSAiY29sb3I6cmVkOyI+IERlIFBERiBhIFdvcmQgPC9zcGFuPg0KYGBge3J9DQpwZGZfZXNvIDwtIHBkZl9jb252ZXJ0KCJDOlxcVXNlcnNcXGVyaWstXFxPbmVEcml2ZVxcRG9jdW1lbnRvc1xcRXNjdWVsYVxcVW5pdmVyc2lkYWRcXDfCulNlbWVzdHJlXFxNb2R1bG9fMlxcZXNvLnBkZiIpICU+JSBtYXAob2NyKQ0KYGBgDQoNCg0KIyA8c3BhbiBzdHlsZSA9ICJjb2xvcjpyZWQ7Ij4gQW7DoWxpc2lzIGRlIEVtb2Npb25lcyB5IFNlbnRpbWllbnRvcyA8L3NwYW4+DQpgYGB7cn0NCnRleHRvIDwtIHBkZl9lc28NCnRleHRvX3BhbGFicmFzIDwtIGdldF90b2tlbnModGV4dG8pDQoNCmVtb2Npb25lcyA8LSBnZXRfbnJjX3NlbnRpbWVudCh0ZXh0b19wYWxhYnJhcywgbGFuZ3VhZ2UgPSAic3BhbmlzaCIpDQoNCnNlbnRpbWllbnRvcyA8LSAoZW1vY2lvbmVzJG5lZ2F0aXZlICogLTEpICsgZW1vY2lvbmVzJHBvc2l0aXZlDQoNCnNpbXBsZV9wbG90KHNlbnRpbWllbnRvcykNCmBgYA0KDQoNCg0KDQoNCg0K