【问题标题】:Appending Dataframe Inside Loop在循环内附加数据框
【发布时间】:2019-08-07 01:19:27
【问题描述】:

我试图通过遍历元素然后单击分页来获取链接列表。我不确定如何在 pandas 数据帧通过如下所示的分页后附加每个循环,以便我可以在循环外调用数据帧以列出所有链接。

它总是覆盖并打印出最后一行。

while True:

    links = [link.get_attribute('href') for link in driver.find_elements_by_class_name('view-detail-link')]

    for link in links:

        df_links = pd.DataFrame([[link]], columns=['link'])

    try:

        NextPage = driver.find_element_by_xpath('//a[@class="ui-pagination-next ui-goto-page"]')
        driver.execute_script("arguments[0].click();", NextPage)

        time.sleep(3)

    except NoSuchElementException:
        break

print(df_links.link[0])

【问题讨论】:

  • 应该避免这种情况见this solution将DataFrames附加到一个列表中,在循环末尾连接一个

标签: python pandas selenium


【解决方案1】:

您需要在循环外创建 DataFrame。然后每次在循环中创建一个新的 DataFrame 时,将它附加到主要的:

df = pd.DataFrame()

while True:

    links = [link.get_attribute('href') for link in driver.find_elements_by_class_name('view-detail-link')]

    for link in links:

        df_links = pd.DataFrame([[link]], columns=['link'])
        df = df.append(df_links)

    try:

        NextPage = driver.find_element_by_xpath('//a[@class="ui-pagination-next ui-goto-page"]')
        driver.execute_script("arguments[0].click();", NextPage)

        time.sleep(3)

    except NoSuchElementException:
        break

print(df.link[0])

【讨论】:

猜你喜欢
  • 1970-01-01
  • 2021-02-05
  • 2018-03-07
  • 1970-01-01
  • 2023-03-17
  • 1970-01-01
  • 2020-12-29
  • 1970-01-01
  • 2021-09-22
相关资源
最近更新 更多