La minerÃa de texto (TM) es el proceso de extraer información útil, patrones o conocimiento de texto no estrucutrados.
Consta de tres etapas:
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 en imágenes.
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.
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.
#install.packages("tidyverse") #Manipulación de datos
library(tidyverse)
#install.packages("tesseract") #Reconocimiento óptico de caracteres (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"
library(purrr)
imagen1 <- image_read("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")
imagen2 <- image_read("imagen2.png")
tesseract_download("spa")
## Training data already exists. Overwriting C:\Users\Lenovo\AppData\Local\tesseract5\tesseract5\tessdata/spa.traineddata
## [1] "C:\\Users\\Lenovo\\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 doc en la computadora
#De PDF a texto en Word
pdf_eso <- pdf_convert("eso.pdf", dpi = 600) %>% 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
imagenes <- pdftools::pdf_convert("eso.pdf", dpi = 300)
## Converting page 1 to eso_1.png... done!
## Converting page 2 to eso_2.png... done!
texto3 <- map(imagenes, ocr) # OCR a cada imagen
# Unir todas las páginas en un solo texto
texto_completo <- paste(texto3, collapse = "\n")
# Crear documento Word y agregar texto
doc3 <- read_docx() %>%
body_add_par(texto_completo)
# Guardar el documento
print(doc3, target = "texto3.docx")
#install.packages("syuzhet") #Análisis de sentimientos
library(syuzhet)
#install.packages("tm")
library(tm)
#install.packages("wordcloud")
library(wordcloud)
#install.packages("RColorBrewer")
library("RColorBrewer")
texto <- pdf_eso
texto_palabras <- get_tokens(texto)
emociones <- get_nrc_sentiment(texto_palabras, language = "spanish")
#Las emociones son: 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"), "hacia","habia","habian","hecho"))
wordcloud(words = palabras, min.freq=2)
## 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