机械化的python网络抓取问题

如何解决机械化的python网络抓取问题

我正在尝试从以下网站抓取网络结果:https://promedmail.org/promed-posts/

我关注了beutifulsoup。机械汤和机械化到目前为止无法抓取搜索结果

import re
from mechanize import browser,urlopen
browser = browser()
browser.set_handle_robots(False)
browser.addheaders = [('User-agent','Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.0.1) Gecko/2008071615 Fedora/3.0.1-1.fc9 Firefox/3.0.1')]
browser.open("https://promedmail.org/promed-posts")
for form in browser.forms():
    if form.attrs['id'] == 'full_search':
        browser.form = form
        break
browser['search'] = 'US'
response = browser.submit()
content = response.read()

在美国输入时,内容不显示搜索结果。知道我在这里做错了什么吗?

解决方法

正如您提到的 bs4,您可以模仿页面发出的 POST 请求。提取包含页面将更新的 html 的 json 项(包含结果);将其解析为 BeautifulSoup 对象,然后将结果表重建为数据框:

import requests
from bs4 import BeautifulSoup as bs

headers = {'user-agent': 'Mozilla/5.0'}

data = {
  'action': 'get_promed_search_content','query[0][name]': 'kwby1','query[0][value]': 'summary','query[1][name]': 'search','query[1][value]': 'US','query[2][name]': 'date1',#  'query[2][value]': '','query[3][name]': 'date2',#  'query[3][value]': '','query[4][name]': 'feed_id','query[4][value]': '1'
}

r = requests.post('https://promedmail.org/wp-admin/admin-ajax.php',headers=headers,data=data).json()
soup = bs(r['results'],'lxml')
df = pd.DataFrame([(i.find_next(text=True),i.a.text,f"https://promedmail.org/promed-post/?id={i.a['id'].replace('id','')}") for i in soup.select('li')],columns = ['Date','Title','Link'])
print(df)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?