嵌套的 For 循环无法存储来自先前迭代的数据

问题描述

我实际上是网络抓取的新手,昨晚刚刚了解它。

简介:

我正在尝试在登录我的帐户时抓取 Science Direct 网页。

我试图在每次迭代中存储所有标题(有三页,即三个迭代),对于每次迭代,我必须爬行我做了另一个 for 循环来读取每个标题的 25 个唯一 ID在每次迭代中。

然而,它只存储了最后一次迭代(第三页)的标题

当我只抓取一个页面时,我知道代码正在工作,但是当我尝试使用第一个 for 循环抓取“下一个页面时:

'''
for (i in seq (from = 0,to = 50,by = 25)) {

'''

正如我之前所说,代码只存储最后一次迭代(即包含 25 篇文章的第 3 页)。

顺便说一下,每个页面都包含一个选项,可以显示每页 25、50 或 100 篇文章,我选择了 25,因此序列 = 25。

代码如下:

#install.packages("xml2") # required for rvest
library("rvest") # for web scraping
library("dplyr") # for data management

titleNo = c()
name = list()
for(i in seq(from = 0,by = 25)) {
  link = paste0("https://www.sciencedirect.com/search?qs=PISA%2C%20Programme%20for%20International%20Student%20Assessment&date=2010-2021&articleTypes=FLA&lastSelectedFacet=subjectAreas&subjectAreas=3300%2C3200%2C2800%2C2000%2C1200%2C1700%2C1400%2C1800%2C2200&offset=",i,"")
  for(j in 1:26) {
    page = read_html(link)
    titleNo[j] = (paste0(".push-m:nth-child(",j,") h2"))
    name[j] <- list(page %>% html_nodes(titleNo[j])%>% html_text())
  }
  print(paste(i))
}

name <- data.frame(unlist(name))

你们能指出我做错了什么吗?

代码成功地运行了所有页面,但我的问题是,对于每次迭代,代码都会清除 name 变量并将新的变量存储到最后一次迭代。

我认为我的问题在于我的 for 循环。我不确定我是否在做正确的事情。

谢谢

解决方法

我认为你把这个问题复杂化了。您可以使用适当的 css 选择器一次性提取 25 个标题。

然后您可以unlist将结果作为一个组合向量来获取。

library(rvest)

values <- seq (from = 25,to = 50,by = 25)
link <- paste0("https://www.sciencedirect.com/search?qs=PISA%2C%20Programme%20for%20International%20Student%20Assessment&date=2010-2021&articleTypes=FLA&lastSelectedFacet=subjectAreas&subjectAreas=3300%2C3200%2C2800%2C2000%2C1200%2C1700%2C1400%2C1800%2C2200&offset=",values)

result <- lapply(link,function(x) x %>%
      read_html() %>%
      html_nodes('div.result-item-content h2 span a') %>%
      html_text())
titles <- unlist(result)
titles

 #[1] "Computer-generated log-file analyses as a window into students' minds? A showcase study based on the PISA 2012 assessment of problem solving"                                                 
 #[2] "The Comparison between Successful and Unsuccessful Countries in PISA,2009"                                                                                                                   
 #[3] "Educational Data Mining: Identification of factors associated with school effectiveness in PISA assessment"                                                                                   
 #[4] "Curriculum standardization,stratification,and students’ STEM-related occupational expectations: Evidence from PISA 2006"                                                                    
 #[5] "Testing measurement invariance of PISA 2015 mathematics,science,and ICT scales using the alignment method"                                                                                  
 #[6] "Effects of students’ and schools’ characteristics on mathematics achievement: findings from PISA 2006"
#...
#...                                                          

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...