首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Python mechanize应该具有值时却为空

Python mechanize应该具有值时却为空
EN

Stack Overflow用户
提问于 2011-03-22 05:26:40
回答 1查看 789关注 0票数 0

我正在尝试自动从webform下载一些数据。我使用的是python的mechanize模块。

网址在这里:http://www.hiv.lanl.gov/components/sequence/HIV/search/search.html我需要填写序列长度,亚型和基因组区域。我已经弄清楚了序列长度和基因组区域,但我在选择亚型时遇到了麻烦。当我加载表单是得到一个空的SelectControl和机械不让我选择任何东西。

下面的代码应该会加载网站:

代码语言:javascript
复制
import mechanize
import cookielib

# Browser
br = mechanize.Browser()

# Cookie Jar
cj = cookielib.LWPCookieJar()
br.set_cookiejar(cj)

# Browser options
br.set_handle_equiv(True)
br.set_handle_gzip(True)
br.set_handle_redirect(True)
br.set_handle_referer(True)
br.set_handle_robots(False)

# Follows refresh 0 but not hangs on refresh > 0
br.set_handle_refresh(mechanize._http.HTTPRefreshProcessor(), max_time=1)

br.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')]

br.open('http://www.hiv.lanl.gov/content/sequence/HIV/mainpage.html')
br.follow_link(text = 'Search Interface')

br.select_form(nr = 1)

任何帮助都将不胜感激。

-Will

编辑:我试着用BeautifulSoup重新解析超文本标记语言(根据这个SO question),但是没有成功。

新编辑:下面是mechanize表单的摘录。

代码语言:javascript
复制
<search POST http://www.hiv.lanl.gov/components/sequence/HIV/search/search.comp multipart/form-data
  <TextControl(value SequenceAccessions SA_GenBankAccession 1=)>
  <SelectControl(master=[Any, *HIV-1, HIV-2, SIV, SHIV, syntheticwholeDNA, NULL])>
  <TextControl(value SEQ_SAMple SSAM_common_name 1=)>
  <SelectControl(slave=[])>
  <TextControl(value SequenceEntry SE_sequenceLength 4=)>
  <CheckboxControl(sample_year_exact=[*1])>
  <TextControl(value SEQ_SAMple SSAM_Sample_year 11=)>
  <TextControl(value SEQ_SAMple SSAM_Sample_country 1=)>
  <CheckboxControl(recombinants=[Recombinants])>

由于某些原因,slave控件未填充可能的选项。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-03-22 09:31:18

问题是,子类型的<select>选项是由Javascript填充的,机械化不会执行。Javascript代码在页面加载时运行,并使用HIV-1列表填充从属选项:

代码语言:javascript
复制
addLoadEvent(fillList(document.forms['search'].slave, lists['HIV-1']));

但是,病毒->亚型的映射存储在this Javascript file 中。您可能需要将此映射存储在Python脚本中,并手动设置从表单值。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5383933

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档