2024-09-30 14:32:43 发布
网友
我正在尝试/想要编写一个Python脚本(2.7),该脚本将转到网站上的表单(名称为"form1"),并用单词hello填充该表单中的第一个输入字段,用单词Ronald填充第二个输入字段,用ronaldG54@gmail.com填充第三个字段
"form1"
hello
Ronald
ronaldG54@gmail.com
有谁能帮我编码或给我任何提示或如何做到这一点?
除了机械化和硒大卫已经提到,它也可以实现与^{}和^{}。
更清楚的是,使用Requests向服务器发送请求并从服务器检索响应,使用BeautifulSoup解析响应html以了解要向服务器发送的参数。
Requests
BeautifulSoup
下面是我编写的一个示例脚本,它使用Requests和BeautifulSoup提交用户名和密码以登录到wikipedia:
import requests from bs4 import BeautifulSoup as bs def get_login_token(raw_resp): soup = bs(raw_resp.text, 'lxml') token = [n['value'] for n in soup.find_all('input') if n['name'] == 'wpLoginToken'] return token[0] payload = { 'wpName': 'my_username', 'wpPassword': 'my_password', 'wpLoginAttempt': 'Log in', #'wpLoginToken': '', } with requests.session() as s: resp = s.get('http://en.wikipedia.org/w/index.php?title=Special:UserLogin') payload['wpLoginToken'] = get_login_token(resp) response_post = s.post('http://en.wikipedia.org/w/index.php?title=Special:UserLogin&action=submitlogin&type=login', data=payload) response = s.get('http://en.wikipedia.org/wiki/Special:Watchlist')
更新:
对于您的具体情况,以下是工作代码:
import requests from bs4 import BeautifulSoup as bs def get_session_id(raw_resp): soup = bs(raw_resp.text, 'lxml') token = soup.find_all('input', {'name':'survey_session_id'})[0]['value'] return token payload = { 'f213054909': 'o213118718', # 21st checkbox 'f213054910': 'Ronald', # first input-field 'f213054911': 'ronaldG54@gmail.com', } url = r'https://app.e2ma.net/app2/survey/39047/213008231/f2e46b57c8/?v=a' with requests.session() as s: resp = s.get(url) payload['survey_session_id'] = get_session_id(resp) response_post = s.post(url, data=payload) print response_post.text
看看Mechanize和Selenium。这两个都是优秀的软件,可以让你自动填写和提交表格,以及其他浏览器任务。
除了机械化和硒大卫已经提到,它也可以实现与^{} 和^{} 。
更清楚的是,使用
Requests
向服务器发送请求并从服务器检索响应,使用BeautifulSoup
解析响应html以了解要向服务器发送的参数。下面是我编写的一个示例脚本,它使用
Requests
和BeautifulSoup
提交用户名和密码以登录到wikipedia:更新:
对于您的具体情况,以下是工作代码:
看看Mechanize和Selenium。这两个都是优秀的软件,可以让你自动填写和提交表格,以及其他浏览器任务。
相关问题 更多 >
编程相关推荐