La minerĂa de texto (TM) es el proceso de extraer informaciĂłn Ăştil, patrones o conocimiento de textos no estructurados. Consta de tres 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 para su interpretaciĂłn. Los mĂ©todos más comunes son 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 usados son el Random Forest, redes neuronales y regresiones. # Instalar paquetes y llamar librerĂas
#install.packages("tidyverse") # ManipulaciĂłn de datos
library(tidyverse)
## Warning: package 'tidyverse' was built under R version 4.4.3
## Warning: package 'ggplot2' was built under R version 4.4.3
## ── 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.2.1
## âś” lubridate 1.9.4 âś” tidyr 1.3.1
## âś” purrr 1.0.4
## ── 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)
## Warning: package 'tesseract' was built under R version 4.4.3
#install.packages("magick") # PNG
library(magick)
## Warning: package 'magick' was built under R version 4.4.3
## Linking to ImageMagick 6.9.13.29
## Enabled features: cairo, freetype, fftw, ghostscript, heic, lcms, pango, raw, rsvg, webp
## Disabled features: fontconfig, x11
#install.packages("officer") # Office (Word)
library(officer)
## Warning: package 'officer' was built under R version 4.4.3
#install.packages("pdftools") # PDF
library(pdftools)
## Warning: package 'pdftools' was built under R version 4.4.3
## Using poppler version 23.08.0
#install.packages("purrr") # Para la funciĂłn "map" para aplicar una funciĂłn a cada elemento de un vector
library(purrr)
imagen1 <- image_read("C:\\Users\\anton\\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 doc1
#print(doc1, target="texto1.docx") # Guarda el doc1 en la compu
Word
imagen2 <- image_read("C:\\Users\\anton\\Downloads\\imagen2.PNG")
tesseract_download("spa")
## Training data already exists. Overwriting C:\Users\anton\AppData\Local\tesseract5\tesseract5\tessdata/spa.traineddata
## [1] "C:\\Users\\anton\\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() # Crea un documento de Word en blanco
doc2 <- doc2 %>% body_add_par(texto2) # Pega el texto en el doc1
# print(doc2, target="texto2.docx") # Guarda el doc1 en la compu
# De PDF a Texto en Word
pdf_eso <- pdf_convert("C:\\Users\\anton\\Downloads\\eso.pdf", dpi=600) %>% map(ocr)
## Converting page 1 to eso_1.png... done!
## Converting page 2 to eso_2.png... done!
#pdf_eso
# Repetir pasos previos para convertir imágenes a texto en Word.
#install.packages("syuzhet") #Análisis de Sentimientos
library(syuzhet)
## Warning: package 'syuzhet' was built under R version 4.4.3
#install.packages("tm") # MinerĂa de Texto
library(tm)
## Warning: package 'tm' was built under R version 4.4.3
## Cargando paquete requerido: NLP
##
## Adjuntando el paquete: 'NLP'
## The following object is masked from 'package:ggplot2':
##
## annotate
#install.packages("wordcloud") # Nube de palabras
library(wordcloud)
## Warning: package 'wordcloud' was built under R version 4.4.3
## Cargando paquete requerido: RColorBrewer
#install.packages("RColorBrewer") # Colores
library(RColorBrewer)
texto <- pdf_eso
texto_palabras <- get_tokens(texto)
emociones <- get_nrc_sentiment(texto_palabras, language = "spanish")
# AlegrĂa, Tristeza, Ira, Miedo, Sopresa, 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"),"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