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:
#install.packages("tidyverse") #MAnipulaciĂ³n de Datos
library(tidyverse)
#install.packages("tesseract") #OCR
library(tesseract)
#install.packages("magick") # PNG
library(magick)
#install.packages("officer") #office (Word)
library(officer)
#install.packages("pdftools")
library(pdftools)
#install.packages("purrr") #FunciĂ³n map para aplicar una funciĂ³n a cada elemento de un vector
library(purrr)
imagen1 <- image_read("C:/Users/rylun/OneDrive/ImĂ¡genes/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 doc
#print(doc1, target="Texto1.docx") #Guarda el documento 1 en la compu
imagen2 <- image_read("C:\\Users\\rylun\\Downloads\\imagen2.PNG")
tesseract_download("spa")
## [1] "C:\\Users\\rylun\\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 doc
#print(doc1, target="Texto2.docx") #Guarda el documento 1 en la compu
imagen1 <- image_read("C:/Users/rylun/OneDrive/ImĂ¡genes/imagen1.PNG")
imagen2 <- image_read("C:/Users/rylun/Downloads/imagen2.PNG")
texto1 <- ocr(imagen1)
tesseract_download("spa")
## Training data already exists. Overwriting C:\Users\rylun\AppData\Local\tesseract5\tesseract5\tessdata/spa.traineddata
## [1] "C:\\Users\\rylun\\AppData\\Local\\tesseract5\\tesseract5\\tessdata/spa.traineddata"
texto2 <- ocr(imagen2, engine = tesseract("spa"))
doc <- read_docx()
doc <- doc %>%
body_add_par("Texto extraĂdo de imagen 1:", style = "heading 1") %>%
body_add_par(texto1) %>%
body_add_par("Texto extraĂdo de imagen 2:", style = "heading 1") %>%
body_add_par(texto2)
#print(doc, target = "Texto_Combinado.docx")
#cat("El archivo 'Texto_Combinado.docx' ha sido guardado correctamente.\n")
#De PDF a Texto en Word
pdf_eso <- pdf_convert("C:\\Users\\rylun\\Downloads\\eso.pdf", dpi = 600) %>% map(ocr)
## Converting page 1 to eso_1.png... done!
## Converting page 2 to eso_2.png... done!
#install.packages("syuzhet") #AnĂ¡lisis de Sentimientos
library(syuzhet)
#install.packages("tm") #MinerĂa de Texto
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")
#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)
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)