2016-08-17 46 views
-2

我想從538拉數據,但我想通過點擊「顯示更多民意調查」到達的完整數據...有沒有任何方法的功能訪問表格的其他行?R拉HTML數據與額外的Java顯示

http://projects.fivethirtyeight.com/2016-election-forecast/national-polls/

在頂級數據拉動的代碼是:

require(XML) 

polls.html <- htmlTreeParse("http://projects.fivethirtyeight.com/2016-election-forecast/national-polls/", 
useInternalNodes = TRUE) 

parsedDoc <- readHTMLTable(polls.html, stringsAsFactors=FALSE) 

pollData <- data.frame(parsedDoc[4]) 
+0

RSelenium是去這裏的最佳方式。 – hrbrmstr

回答

0

我,爲什麼這引起了downvoted有點糊塗了......似乎仍不明顯,我!但對於任何想知道解決方案的人來說,我都明白(感謝@duncantl的幫助)。 (此外,完整的分析是:https://github.com/hardin47/prediction2016

require(XML) 
require(dplyr) 
require(tidyr) 
require(readr) 
require(mosaic) 
require(RCurl) 
require(ggplot2) 
require(lubridate) 
require(RJSONIO) 

url = "http://projects.fivethirtyeight.com/2016-election-forecast/national-polls/" 
doc <- htmlParse(url, useInternalNodes = TRUE) 

sc = xpathSApply(doc, "//script[contains(., 'race.model')]", 
       function(x) c(xmlValue(x), xmlAttrs(x)[["href"]])) 

jsobj = gsub(".*race.stateData = (.*);race.pathPrefix.*", "\\1", sc) 

data = fromJSON(jsobj) 
allpolls <- data$polls 

#unlisting the whole thing 
indx <- sapply(allpolls, length) 
pollsdf <- as.data.frame(do.call(rbind, lapply(allpolls, `length<-`, max(indx)))) 

#unlisting the weights 
pollswt <- as.data.frame(t(as.data.frame(do.call(cbind, lapply(pollsdf$weight, data.frame, 
               stringsAsFactors=FALSE))))) 
names(pollswt) <- c("wtpolls", "wtplus", "wtnow") 
row.names(pollswt) <- NULL 

pollsdf <- cbind(pollsdf, pollswt) 

#unlisting the voting 
indxv <- sapply(pollsdf$votingAnswers, length) 
pollsvot <- as.data.frame(do.call(rbind, lapply(pollsdf$votingAnswers, 
               `length<-`, max(indxv)))) 
pollsvot1 <- rbind(as.data.frame(do.call(rbind, lapply(pollsvot$V1, data.frame, 
               stringsAsFactors=FALSE)))) 
pollsvot2 <- rbind(as.data.frame(do.call(rbind, lapply(pollsvot$V2, data.frame, 
               stringsAsFactors=FALSE)))) 


pollsvot1 <- cbind(polltype = rownames(pollsvot1), pollsvot1, 
        polltypeA = gsub('[0-9]+', '', rownames(pollsvot1)), 
        polltype1 = extract_numeric(rownames(pollsvot1))) 

pollsvot1$polltype1 <- ifelse(is.na(pollsvot1$polltype1), 1, pollsvot1$polltype1 + 1) 


pollsvot2 <- cbind(polltype = rownames(pollsvot2), pollsvot2, 
        polltypeA = gsub('[0-9]+', '', rownames(pollsvot2)), 
        polltype1 = extract_numeric(rownames(pollsvot2))) 

pollsvot2$polltype1 <- ifelse(is.na(pollsvot2$polltype1), 1, pollsvot2$polltype1 + 1) 


pollsdf <- pollsdf %>% 
    mutate(population = unlist(population), 
     sampleSize = as.numeric(unlist(sampleSize)), 
     pollster = unlist(pollster), 
     startDate = ymd(unlist(startDate)), 
     endDate = ymd(unlist(endDate)), 
     pollsterRating = unlist(pollsterRating)) %>% 
    select(population, sampleSize, pollster, startDate, endDate, pollsterRating, 
     wtpolls, wtplus, wtnow) 



allpolldata <- cbind(rbind(pollsdf[rep(seq_len(nrow(pollsdf)), each=3),], 
          pollsdf[rep(seq_len(nrow(pollsdf)), each=3),]), 
        rbind(pollsvot1, pollsvot2)) 

allpolldata <- allpolldata %>% 
    arrange(polltype1, choice)