Teoría

EL Reconocimiento Óptico de Caracteres (OCR) es una tecnología utilizada para convertir diferentes tipos de documentos, como imágenes, docuemtnos impresos escneados, fotografías de texto, archivos PDF o imágenes capturadas con una cámara, en datos editables y buscables.

La Mineria de Datos (TM) es el proceso de extraer información útil, patrones o conocimiento de texts 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ágenes. 2 Explorar datos: Representación gráfica o visual de los datos apra su interpretación. Los métodos más comunes son el Ánalisis de Sentimientos, la Nube de Palabras y el Topic Modeling. 3. Ánalisis predictivo: Son las técnicas y modelos estadísticos para predicir resultados futuros. Los modelos más usasdos son el Random Forest, redes neuronales y regresiones.

Instalar paquetes y llamar librerias

#install.packages("tidyverse")
library(tidyverse)
## ── Attaching core tidyverse packages ──────────────────────── tidyverse 2.0.0 ──
## ✔ dplyr     1.1.4     ✔ readr     2.1.5
## ✔ forcats   1.0.0     ✔ stringr   1.5.1
## ✔ ggplot2   3.5.2     ✔ tibble    3.3.0
## ✔ lubridate 1.9.4     ✔ tidyr     1.3.1
## ✔ purrr     1.1.0     
## ── Conflicts ────────────────────────────────────────── tidyverse_conflicts() ──
## ✖ dplyr::filter() masks stats::filter()
## ✖ dplyr::lag()    masks stats::lag()
## ℹ Use the conflicted package (<http://conflicted.r-lib.org/>) to force all conflicts to become errors
#install.packages("tesseract")
library(tesseract)
#install.packages("magick")
library(magick)
## Linking to ImageMagick 6.9.12.98
## Enabled features: cairo, freetype, fftw, ghostscript, heic, lcms, pango, raw, rsvg, webp
## Disabled features: fontconfig, x11
#install.packages("officer")
library(officer)
#install.packages("pdftools")
library(pdftools)
## Using poppler version 25.05.0
#install.packages("purrr")
library(purrr)
#install.packages("syuzhet")
library(syuzhet)
#install.packages("tm")
library(tm)
## Cargando paquete requerido: NLP
## 
## Adjuntando el paquete: 'NLP'
## 
## The following object is masked from 'package:ggplot2':
## 
##     annotate
#install.packages("wordcloud")
library(wordcloud)
## Cargando paquete requerido: RColorBrewer
#install.packages("RColorBrewer")
library(RColorBrewer)

DE imagen PNG a texto en Word

imagen1 <- image_read("C:\\Users\\usuario\\Desktop\\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 imagen PNG en Español a texto en Word

imagen2<- image_read("C:\\Users\\usuario\\Desktop\\imagen2.PNG")
tesseract_download("spa")
## Training data already exists. Overwriting C:\Users\usuario\AppData\Local\tesseract5\tesseract5\tessdata/spa.traineddata
## [1] "C:\\Users\\usuario\\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="texto3.docx")

De PDF a texto en Word

pdf_eso <- pdf_convert("C:\\Users\\usuario\\Desktop\\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 imagenes 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")
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)
## 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

LS0tDQp0aXRsZTogIk9DUiINCmF1dGhvcjogIkpvcmdlIFBvbnMgRGlheiBJbmZhbnRlIC0gQTAxNDI0MTA4Ig0KZGF0ZTogIjIwMjUtMDgtMjAiDQpvdXRwdXQ6IA0KICBodG1sX2RvY3VtZW50Og0KICAgIHRvYzogVFJVRQ0KICAgIHRvY19mbG9hdDogVFJVRQ0KICAgIGNvZGVfZG93bmxvYWQ6IFRSVUUNCiAgICB0aGVtZSA6IHNpbXBsZXgNCi0tLQ0KDQohW10oaHR0cHM6Ly9pLnBpbmltZy5jb20vb3JpZ2luYWxzLzIxL2QwLzZkLzIxZDA2ZGVhZDcwN2Q1MDgyZTc4ZWYzOGM5MDUzZjgwLmdpZikNCg0KIyA8c3BhbiBzdHlsZT0iY29sb3I6Ymx1ZSI+IFRlb3LDrWEgPC9zcGFuPiANCkVMICoqUmVjb25vY2ltaWVudG8gw5NwdGljbyBkZSBDYXJhY3RlcmVzIChPQ1IpKiogZXMgdW5hIHRlY25vbG9nw61hIHV0aWxpemFkYSBwYXJhIGNvbnZlcnRpciBkaWZlcmVudGVzIHRpcG9zIGRlIGRvY3VtZW50b3MsIGNvbW8gaW3DoWdlbmVzLCBkb2N1ZW10bm9zIGltcHJlc29zIGVzY25lYWRvcywgZm90b2dyYWbDrWFzIGRlIHRleHRvLCBhcmNoaXZvcyBQREYgbyBpbcOhZ2VuZXMgY2FwdHVyYWRhcyBjb24gdW5hIGPDoW1hcmEsIGVuIGRhdG9zIGVkaXRhYmxlcyB5IGJ1c2NhYmxlcy4NCg0KTGEgKipNaW5lcmlhIGRlIERhdG9zIChUTSkqKiBlcyBlbCBwcm9jZXNvIGRlIGV4dHJhZXIgaW5mb3JtYWNpw7NuIMO6dGlsLCBwYXRyb25lcyBvIGNvbm9jaW1pZW50byBkZSB0ZXh0cyBubyBlc3RydWN0dXJhZG9zLg0KDQpDb25zdGEgZGUgMyBldGFwYXM6DQoxLiBPYnRlbmVyIGRhdG9zOiBFbCByZWNvbm9jaW1pZW50byDDk3B0aWNvIGRlIENhcmFjdGVyZXMoT0NSKSBlcyB1bmEgdGVjbm9sb2fDrWEgcXVlIHBlcm1pdGUgY29udmVydGlyIGltw6FnZW5lcyBkZSB0ZXh0byBlbiB0ZXh0byBlZGl0YWJsZS4gVGFtYmnDqW4gZXMgY29ub2NpZG8gY29tbyBleHRyYWNjacOzbiBkZSB0ZXh0byBkZSBpbcOhZ2VuZXMuDQoyIEV4cGxvcmFyIGRhdG9zOiBSZXByZXNlbnRhY2nDs24gZ3LDoWZpY2EgbyB2aXN1YWwgZGUgbG9zIGRhdG9zIGFwcmEgc3UgaW50ZXJwcmV0YWNpw7NuLiBMb3MgbcOpdG9kb3MgbcOhcyBjb211bmVzIHNvbiBlbCDDgW5hbGlzaXMgZGUgU2VudGltaWVudG9zLCBsYSBOdWJlIGRlIFBhbGFicmFzIHkgZWwgVG9waWMgTW9kZWxpbmcuDQozLiDDgW5hbGlzaXMgcHJlZGljdGl2bzogU29uIGxhcyB0w6ljbmljYXMgeSBtb2RlbG9zIGVzdGFkw61zdGljb3MgcGFyYSBwcmVkaWNpciByZXN1bHRhZG9zIGZ1dHVyb3MuIExvcyBtb2RlbG9zIG3DoXMgdXNhc2RvcyBzb24gZWwgUmFuZG9tIEZvcmVzdCwgcmVkZXMgbmV1cm9uYWxlcyB5IHJlZ3Jlc2lvbmVzLg0KDQojIDxzcGFuIHN0eWxlPSJjb2xvcjpibHVlIj4gSW5zdGFsYXIgcGFxdWV0ZXMgeSBsbGFtYXIgbGlicmVyaWFzIDwvc3Bhbj4gDQpgYGB7cn0NCiNpbnN0YWxsLnBhY2thZ2VzKCJ0aWR5dmVyc2UiKQ0KbGlicmFyeSh0aWR5dmVyc2UpDQojaW5zdGFsbC5wYWNrYWdlcygidGVzc2VyYWN0IikNCmxpYnJhcnkodGVzc2VyYWN0KQ0KI2luc3RhbGwucGFja2FnZXMoIm1hZ2ljayIpDQpsaWJyYXJ5KG1hZ2ljaykNCiNpbnN0YWxsLnBhY2thZ2VzKCJvZmZpY2VyIikNCmxpYnJhcnkob2ZmaWNlcikNCiNpbnN0YWxsLnBhY2thZ2VzKCJwZGZ0b29scyIpDQpsaWJyYXJ5KHBkZnRvb2xzKQ0KI2luc3RhbGwucGFja2FnZXMoInB1cnJyIikNCmxpYnJhcnkocHVycnIpDQojaW5zdGFsbC5wYWNrYWdlcygic3l1emhldCIpDQpsaWJyYXJ5KHN5dXpoZXQpDQojaW5zdGFsbC5wYWNrYWdlcygidG0iKQ0KbGlicmFyeSh0bSkNCiNpbnN0YWxsLnBhY2thZ2VzKCJ3b3JkY2xvdWQiKQ0KbGlicmFyeSh3b3JkY2xvdWQpDQojaW5zdGFsbC5wYWNrYWdlcygiUkNvbG9yQnJld2VyIikNCmxpYnJhcnkoUkNvbG9yQnJld2VyKQ0KYGBgDQoNCiMgPHNwYW4gc3R5bGU9ImNvbG9yOmJsdWUiPiBERSBpbWFnZW4gUE5HIGEgdGV4dG8gZW4gV29yZCA8L3NwYW4+IA0KYGBge3J9DQppbWFnZW4xIDwtIGltYWdlX3JlYWQoIkM6XFxVc2Vyc1xcdXN1YXJpb1xcRGVza3RvcFxcaW1hZ2VuMS5QTkciKQ0KdGV4dG8xIDwtIG9jcihpbWFnZW4xKQ0KdGV4dG8xDQpkb2MxIDwtIHJlYWRfZG9jeCgpDQpkb2MxIDwtIGRvYzEgJT4lIGJvZHlfYWRkX3Bhcih0ZXh0bzEpDQojcHJpbnQoZG9jMSwgdGFyZ2V0PSJ0ZXh0bzEuZG9jeCIpDQpgYGANCg0KIyA8c3BhbiBzdHlsZT0iY29sb3I6Ymx1ZSI+IERFIGltYWdlbiBQTkcgZW4gRXNwYcOxb2wgYSB0ZXh0byBlbiBXb3JkIDwvc3Bhbj4gDQpgYGB7cn0NCmltYWdlbjI8LSBpbWFnZV9yZWFkKCJDOlxcVXNlcnNcXHVzdWFyaW9cXERlc2t0b3BcXGltYWdlbjIuUE5HIikNCnRlc3NlcmFjdF9kb3dubG9hZCgic3BhIikNCnRleHRvMiA8LSBvY3IoaW1hZ2VuMiwgZW5naW5lID0gdGVzc2VyYWN0KCJzcGEiKSkNCnRleHRvMg0KZG9jMiA8LSByZWFkX2RvY3goKQ0KZG9jMiA8LSBkb2MyICU+JSBib2R5X2FkZF9wYXIodGV4dG8yKQ0KI3ByaW50KGRvYzIsIHRhcmdldD0idGV4dG8zLmRvY3giKQ0KYGBgDQoNCiMgPHNwYW4gc3R5bGU9ImNvbG9yOmJsdWUiPiBEZSBQREYgYSB0ZXh0byBlbiBXb3JkIDwvc3Bhbj4gDQpgYGB7cn0NCnBkZl9lc28gPC0gcGRmX2NvbnZlcnQoIkM6XFxVc2Vyc1xcdXN1YXJpb1xcRGVza3RvcFxcZXNvLnBkZiIpICU+JSBtYXAob2NyKQ0KIyBSZXBldGlyIHBhc29zIHByZXZpb3MgcGFyYSBjb252ZXJ0aXIgaW1hZ2VuZXMgYSB0ZXh0byBlbiBXb3JkDQpgYGANCg0KIyA8c3BhbiBzdHlsZT0iY29sb3I6Ymx1ZSI+IEFuw6FsaXNpcyBkZSBFbW9jaW9uZXMgeSBTZW50aW1pZW50b3MgPC9zcGFuPiANCmBgYHtyfQ0KdGV4dG8gPC0gcGRmX2Vzbw0KdGV4dG9fcGFsYWJyYXMgPC0gZ2V0X3Rva2Vucyh0ZXh0bykNCmVtb2Npb25lcyA8LSBnZXRfbnJjX3NlbnRpbWVudCh0ZXh0b19wYWxhYnJhcywgbGFuZ3VhZ2UgPSAic3BhbmlzaCIpDQpiYXJwbG90KGNvbFN1bXMocHJvcC50YWJsZShlbW9jaW9uZXNbLDE6OF0pKSkNCnNlbnRpbWllbnRvcyA8LSAoZW1vY2lvbmVzJG5lZ2F0aXZlKi0xKStlbW9jaW9uZXMkcG9zaXRpdmUNCnNpbXBsZV9wbG90KHNlbnRpbWllbnRvcykNCmBgYA0KDQoNCiMgPHNwYW4gc3R5bGU9ImNvbG9yOmJsdWUiPiBOdWJlIGRlIFBhbGFicmFzIDwvc3Bhbj4gDQpgYGB7cn0NCnBhbGFicmFzIDwtIHRleHRvX3BhbGFicmFzDQpwYWxhYnJhcyA8LSByZW1vdmVXb3JkcyhwYWxhYnJhcywgYyhzdG9wd29yZHMoInNwYW5pc2giKSwiaGFiaWEiLCJoYWNpYSIsImNhc2kiKSkNCndvcmRjbG91ZCh3b3JkcyA9IHBhbGFicmFzLCBtaW4uZnJlcT0yLCByb3QucGVyPTAsIHJhbmRvbS5vcmRlcj1GQUxTRSkNCg0KYGBgDQoNCg==