TeorĆ­a

El Reconocimiento Ɠptico de Caracteres (OCR) es una tecnologĆ­a utilizada para convertir diferentes tipos de documentos, como de imĆ”genes, documentos impresos escaneados, fotografĆ­as de textos, 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 conocimientos de textos no estructurados.

Consta de 3 etapas: 1. Obtener datos: El reconocimiento Ɠptico de Caracteres (ORC) es una tecnologĆ­a que permite convertir imagenes de texto editable. TambiĆ©n es conocido como extracción de texto de imagenes. 2.⁠ ⁠Explorar datos: Representación grĆ”fica o visual de los datos para su interpretación. Los mĆ©todos mĆ”s comunes son el Ɓnalisis de Sentimientos, la Nube de Palabaras 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 regresiones.

Instalar paquetes y llamar librerĆ­as

#install.packages("tidyverse") # Manipulacion de datos
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") # OCR
library(tesseract)
#install.packages("magick") # PNG
library(magick)
## Linking to ImageMagick 6.9.12.93
## Enabled features: cairo, fontconfig, freetype, heic, lcms, pango, raw, rsvg, webp
## Disabled features: fftw, ghostscript, x11
#install.packages("officer") # Office (Word)
library(officer)
#install.packages("pdftools") # PDF
library(pdftools)
## Using poppler version 23.04.0
#install.packages("purrr") # Para la función "map" para aplicar una función a cada elemento de un vector
library(purrr)
#install.packages("syuzhet") # Analisis de sentimientos
library(syuzhet)
#install.packages("tm")
library(tm) # Mineria de datos
## Loading required package: NLP
## 
## Attaching package: 'NLP'
## 
## The following object is masked from 'package:ggplot2':
## 
##     annotate
#install.packages("wordcloud") # Nube de palabras
library(wordcloud)
## Loading required package: RColorBrewer
#install.packages("RColorBrewer") # Paletas de colores
library(RColorBrewer)
#install.packages("tm")
library(tm)

De imagen PNG a texto en Word

imagen1 <- image_read( "/Users/ximenabbm/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 de word en blanco
doc1 <- doc1 %>% body_add_par(texto1) #Pega el 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("/Users/ximenabbm/Downloads/imagen2.PNG")
tesseract_download("spa") #Descarga el paquete de idioma espaƱol
## Training data already exists. Overwriting /Users/ximenabbm/Library/Application Support/tesseract5/tessdata/spa.traineddata
## [1] "/Users/ximenabbm/Library/Application Support/tesseract5/tessdata/spa.traineddata"
texto2 <- ocr(imagen2, engine = tesseract("spa")) #Especifica el idioma espaƱol
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() #Crea un documento de word en blanco
doc2 <- doc2 %>% body_add_par(texto2) #Pega el texto en el documento
print(doc2, target = "texto2.docx") #Guarda el documento en la computadora

De PDF a texto en Word

pdf_eso <- pdf_convert("/Users/ximenabbm/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 imagenes a texto en Word

Analisis de emociones y sentimientos

texto <- pdf_eso
texto_palabras <- get_tokens(texto)
emociones <- get_nrc_sentiment(texto_palabras, language = "spanish")
#Alegría, Tristeza, Miedo, Sorpresa, Ira, 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)

LS0tCnRpdGxlOiAiT0NSIgphdXRob3I6ICJYaW1lbmEgQm9sYcOxb3MiCmRhdGU6ICIyMDI1LTA4LTIwIgpvdXRwdXQ6CiAgaHRtbF9kb2N1bWVudDogCiAgICB0b2M6IFRSVUUKICAgIHRvY19mbG9hdDogVFJVRQogICAgY29kZV9kb3dubG9hZDogVFJVRSAKICAgIHRoZW1lOiBzaW1wbGV4Ci0tLQoKIVtdKGh0dHBzOi8vbWVkaWEudGVub3IuY29tL0M2XzdOTEtxNnM4QUFBQU0vaXQtcGVubnl3aXNlLmdpZikKCiMgPHNwYW4gc3R5bGU9ImNvbG9yOmJsdWUiPiBUZW9yw61hIDwvc3Bhbj4KRWwgKipSZWNvbm9jaW1pZW50byDDk3B0aWNvIGRlIENhcmFjdGVyZXMgKE9DUikqKiBlcyB1bmEgdGVjbm9sb2fDrWEgdXRpbGl6YWRhIHBhcmEgY29udmVydGlyIGRpZmVyZW50ZXMgdGlwb3MgZGUgZG9jdW1lbnRvcywgY29tbyBkZSBpbcOhZ2VuZXMsIGRvY3VtZW50b3MgaW1wcmVzb3MgZXNjYW5lYWRvcywgZm90b2dyYWbDrWFzIGRlIHRleHRvcywgYXJjaGl2b3MgUERGIG8gaW3DoWdlbmVzIGNhcHR1cmFkYXMgY29uIHVuYSBjw6FtYXJhLCBlbiBkYXRvcyBlZGl0YWJsZXMgeSBidXNjYWJsZXMuCgpMYSAqKk1pbmVyaWEgZGUgRGF0b3MgKFRNKSoqIGVzIGVsIHByb2Nlc28gZGUgZXh0cmFlciBpbmZvcm1hY2nDs24gw7p0aWwsIHBhdHJvbmVzIG8gY29ub2NpbWllbnRvcyBkZSB0ZXh0b3Mgbm8gZXN0cnVjdHVyYWRvcy4KCkNvbnN0YSBkZSAzIGV0YXBhczoKMS4gT2J0ZW5lciBkYXRvczogRWwgcmVjb25vY2ltaWVudG8gw5NwdGljbyBkZSBDYXJhY3RlcmVzIChPUkMpIGVzIHVuYSB0ZWNub2xvZ8OtYSBxdWUgcGVybWl0ZSBjb252ZXJ0aXIgaW1hZ2VuZXMgZGUgdGV4dG8gZWRpdGFibGUuIFRhbWJpw6luIGVzIGNvbm9jaWRvIGNvbW8gZXh0cmFjY2nDs24gZGUgdGV4dG8gZGUgaW1hZ2VuZXMuCjIu4oGgIOKBoEV4cGxvcmFyIGRhdG9zOiBSZXByZXNlbnRhY2nDs24gZ3LDoWZpY2EgbyB2aXN1YWwgZGUgbG9zIGRhdG9zIHBhcmEgc3UgaW50ZXJwcmV0YWNpw7NuLiBMb3MgbcOpdG9kb3MgbcOhcyBjb211bmVzIHNvbiBlbCDDgW5hbGlzaXMgZGUgU2VudGltaWVudG9zLCBsYSBOdWJlIGRlIFBhbGFiYXJhcyB5IGVsIFRvcGljIE1vZGVsaW5nLgozLuKBoCDigaBBbsOhbGlzaXMgcHJlZGljdGl2bzogU29uIGxhcyB0w6ljbmljYXMgeSBtb2RlbG9zIGVzdGFkw61zdGljb3MgcGFyYSBwcmVkZWNpciByZXN1bHRhZG9zIGZ1dHVyb3MuIExvcyBtb2RlbG9zIG3DoXMgdXNhZG9zIHNvbiBlbCBSYW5kb20gRm9yZXN0LCByZWRlcyBuZXVyb25hbGVzIHkgcmVncmVzaW9uZXMuCgojIDxzcGFuIHN0eWxlPSJjb2xvcjpyZWQiPkluc3RhbGFyIHBhcXVldGVzIHkgbGxhbWFyIGxpYnJlcsOtYXM8L3NwYW4+CmBgYHtyfQojaW5zdGFsbC5wYWNrYWdlcygidGlkeXZlcnNlIikgIyBNYW5pcHVsYWNpb24gZGUgZGF0b3MKbGlicmFyeSh0aWR5dmVyc2UpCiNpbnN0YWxsLnBhY2thZ2VzKCJ0ZXNzZXJhY3QiKSAjIE9DUgpsaWJyYXJ5KHRlc3NlcmFjdCkKI2luc3RhbGwucGFja2FnZXMoIm1hZ2ljayIpICMgUE5HCmxpYnJhcnkobWFnaWNrKQojaW5zdGFsbC5wYWNrYWdlcygib2ZmaWNlciIpICMgT2ZmaWNlIChXb3JkKQpsaWJyYXJ5KG9mZmljZXIpCiNpbnN0YWxsLnBhY2thZ2VzKCJwZGZ0b29scyIpICMgUERGCmxpYnJhcnkocGRmdG9vbHMpCiNpbnN0YWxsLnBhY2thZ2VzKCJwdXJyciIpICMgUGFyYSBsYSBmdW5jacOzbiAibWFwIiBwYXJhIGFwbGljYXIgdW5hIGZ1bmNpw7NuIGEgY2FkYSBlbGVtZW50byBkZSB1biB2ZWN0b3IKbGlicmFyeShwdXJycikKI2luc3RhbGwucGFja2FnZXMoInN5dXpoZXQiKSAjIEFuYWxpc2lzIGRlIHNlbnRpbWllbnRvcwpsaWJyYXJ5KHN5dXpoZXQpCiNpbnN0YWxsLnBhY2thZ2VzKCJ0bSIpCmxpYnJhcnkodG0pICMgTWluZXJpYSBkZSBkYXRvcwojaW5zdGFsbC5wYWNrYWdlcygid29yZGNsb3VkIikgIyBOdWJlIGRlIHBhbGFicmFzCmxpYnJhcnkod29yZGNsb3VkKQojaW5zdGFsbC5wYWNrYWdlcygiUkNvbG9yQnJld2VyIikgIyBQYWxldGFzIGRlIGNvbG9yZXMKbGlicmFyeShSQ29sb3JCcmV3ZXIpCiNpbnN0YWxsLnBhY2thZ2VzKCJ0bSIpCmxpYnJhcnkodG0pCmBgYAoKIyA8c3BhbiBzdHlsZT0iY29sb3I6cmVkIj5EZSBpbWFnZW4gUE5HIGEgdGV4dG8gZW4gV29yZDwvc3Bhbj4KYGBge3J9CmltYWdlbjEgPC0gaW1hZ2VfcmVhZCggIi9Vc2Vycy94aW1lbmFiYm0vRG93bmxvYWRzL2ltYWdlbjEuUE5HIikKdGV4dG8xIDwtIG9jcihpbWFnZW4xKQp0ZXh0bzEKZG9jMSA8LSByZWFkX2RvY3goKSAjQ3JlYSB1biBkb2N1bWVudG8gZGUgd29yZCBlbiBibGFuY28KZG9jMSA8LSBkb2MxICU+JSBib2R5X2FkZF9wYXIodGV4dG8xKSAjUGVnYSBlbCB0ZXh0byBlbiBlbCBkb2N1bWVudG8KcHJpbnQoZG9jMSwgdGFyZ2V0ID0gInRleHRvMS5kb2N4IikgI0d1YXJkYSBlbCBkb2N1bWVudG8gZW4gbGEgY29tcHV0YWRvcmEKYGBgCgojIDxzcGFuIHN0eWxlPSJjb2xvcjpyZWQiPkRlIGltYWdlbiBQTkcgZW4gZXNwYcOxb2wgYSB0ZXh0byBlbiBXb3JkPC9zcGFuPgpgYGB7cn0KaW1hZ2VuMiA8LSBpbWFnZV9yZWFkKCIvVXNlcnMveGltZW5hYmJtL0Rvd25sb2Fkcy9pbWFnZW4yLlBORyIpCnRlc3NlcmFjdF9kb3dubG9hZCgic3BhIikgI0Rlc2NhcmdhIGVsIHBhcXVldGUgZGUgaWRpb21hIGVzcGHDsW9sCnRleHRvMiA8LSBvY3IoaW1hZ2VuMiwgZW5naW5lID0gdGVzc2VyYWN0KCJzcGEiKSkgI0VzcGVjaWZpY2EgZWwgaWRpb21hIGVzcGHDsW9sCnRleHRvMgpkb2MyIDwtIHJlYWRfZG9jeCgpICNDcmVhIHVuIGRvY3VtZW50byBkZSB3b3JkIGVuIGJsYW5jbwpkb2MyIDwtIGRvYzIgJT4lIGJvZHlfYWRkX3Bhcih0ZXh0bzIpICNQZWdhIGVsIHRleHRvIGVuIGVsIGRvY3VtZW50bwpwcmludChkb2MyLCB0YXJnZXQgPSAidGV4dG8yLmRvY3giKSAjR3VhcmRhIGVsIGRvY3VtZW50byBlbiBsYSBjb21wdXRhZG9yYQpgYGAKCiMgPHNwYW4gc3R5bGU9ImNvbG9yOnJlZCI+RGUgUERGIGEgdGV4dG8gZW4gV29yZDwvc3Bhbj4KYGBge3J9CnBkZl9lc28gPC0gcGRmX2NvbnZlcnQoIi9Vc2Vycy94aW1lbmFiYm0vRG93bmxvYWRzL2Vzby5wZGYiKSAlPiUgbWFwKG9jcikKI1JlcGV0aXIgcGFzb3MgcHJldmlvcyBwYXJhIGNvbnZlcnRpciBpbWFnZW5lcyBhIHRleHRvIGVuIFdvcmQKYGBgCgojIDxzcGFuIHN0eWxlPSJjb2xvcjpyZWQiPiBBbmFsaXNpcyBkZSBlbW9jaW9uZXMgeSBzZW50aW1pZW50b3MgPC9zcGFuPgpgYGB7cn0KdGV4dG8gPC0gcGRmX2Vzbwp0ZXh0b19wYWxhYnJhcyA8LSBnZXRfdG9rZW5zKHRleHRvKQplbW9jaW9uZXMgPC0gZ2V0X25yY19zZW50aW1lbnQodGV4dG9fcGFsYWJyYXMsIGxhbmd1YWdlID0gInNwYW5pc2giKQojQWxlZ3LDrWEsIFRyaXN0ZXphLCBNaWVkbywgU29ycHJlc2EsIElyYSwgQXNjbywgQW50aWNpcGFjacOzbiwgQ29uZmlhbnphCmJhcnBsb3QoY29sU3Vtcyhwcm9wLnRhYmxlKGVtb2Npb25lc1ssMTo4XSkpKQpzZW50aW1pZW50b3MgPC0gKGVtb2Npb25lcyRuZWdhdGl2ZSAqLTEpK2Vtb2Npb25lcyRwb3NpdGl2ZQpzaW1wbGVfcGxvdChzZW50aW1pZW50b3MpCmBgYAojIDxzcGFuIHN0eWxlPSJjb2xvcjpyZWQiPiBOdWJlIGRlIHBhbGFicmFzIDwvc3Bhbj4KYGBge3IgbWVzc2FnZT1GQUxTRSwgd2FybmluZz1GQUxTRX0KcGFsYWJyYXMgPC0gdGV4dG9fcGFsYWJyYXMKcGFsYWJyYXMgPC0gcmVtb3ZlV29yZHMocGFsYWJyYXMsIGMoc3RvcHdvcmRzKCJzcGFuaXNoIiksICJoYWJpYSIsICJoYWNpYSIsICJjYXNpIikpCndvcmRjbG91ZCh3b3Jkcz1wYWxhYnJhcywgbWluLmZyZXE9Miwgcm90LnBlcj0wLCByYW5kb20ub3JkZXI9RkFMU0UpCmBgYAoKCgoK