当前位置: 首页 > news >正文

马鞍山专业网站制作公司动画设计视频教程

马鞍山专业网站制作公司,动画设计视频教程,湖南小企业网站建设怎么做,句容市建设工程管理处网站最近看的关于网络爬虫和模拟登陆的资料#xff0c;发现有这样一个包 mechanize [mekə.naɪz]又称为机械化的意思#xff0c;确实文如其意#xff0c;确实有自动化的意思。 mechanize.Browser and mechanize.UserAgentBase implement the interface of urllib2.OpenerDirect…最近看的关于网络爬虫和模拟登陆的资料发现有这样一个包   mechanize [mekə.naɪz]又称为机械化的意思确实文如其意确实有自动化的意思。 mechanize.Browser and mechanize.UserAgentBase implement the interface of urllib2.OpenerDirector, so: any URL can be opened, not just http: mechanize.UserAgentBase offers easy dynamic configuration of user-agent features like protocol, cookie, redirection and robots.txt handling, without having to make a new OpenerDirector each time, e.g. by calling build_opener(). Easy HTML form filling. Convenient link parsing and following. Browser history (.back() and .reload() methods). The Referer HTTP header is added properly (optional). Automatic observance of robots.txt. Automatic handling of HTTP-Equiv and Refresh. 意思就是说 mechanize.Browser和mechanize.UserAgentBase只是urllib2.OpenerDirector的接口实现因此包括HTTP协议所有的协议都可以打开 另外提供了更简单的配置方式而不用每次都创建一个新的OpenerDirector 对表单的操作对链接的操作、浏览历史和重载操作、刷新、对robots.txt的监视操作等等 import re import mechanize 1实例化一个浏览器对象 br mechanize.Browser() 2打开一个网址br.open(http://www.example.com/) 3该网页下的满足text_regex的第2个链接# follow second link with element text matching regular expression response1 br.follow_link(text_regexrcheese\s*shop, nr1) assert br.viewing_html() 4网页的名称print br.title() 5将网页的网址打印出来print response1.geturl() 6网页的头部print response1.info() # headers 7网页的bodyprint response1.read() # body (8)选择body中的name order的FORM br.select_form(nameorder) # Browser passes through unknown attributes (including methods) # to the selected HTMLForm.(9)为name cheeses的form赋值 br[cheeses] [mozzarella, caerphilly] # (the method here is __setitem__) # Submit current form. Browser calls .close() on the current response on # navigation, so this closes response1 10提交response2 br.submit()# print currently selected form (dont call .submit() on this, use br.submit()) print br.form 11返回 response3 br.back() # back to cheese shop (same data as response1) # the history mechanism returns cached response objects # we can still use the response, even though it was .close()dresponse3.get_data() # like .seek(0) followed by .read() 12刷新网页response4 br.reload() # fetches from server13这可以列出该网页下所有的Formfor form in br.forms():print form # .links() optionally accepts the keyword args of .follow_/.find_link() for link in br.links(url_regexpython.org): print linkbr.follow_link(link) # takes EITHER Link instance OR keyword argsbr.back()这是文档中给出的一个例子,基本的解释已经在代码中给出 You may control the browser’s policy by using the methods of mechanize.Browser’s base class, mechanize.UserAgent. For example: 通过mechanize.UserAgent这个模块我们可以实现对browser’s policy的控制代码给出如下也是来自与文档的例子 br mechanize.Browser() # Explicitly configure proxies (Browser will attempt to set good defaults). # Note the userinfo (joe:password) and port number (:3128) are optional. br.set_proxies({http: joe:passwordmyproxy.example.com:3128, ftp: proxy.example.com,}) # Add HTTP Basic/Digest auth username and password for HTTP proxy access. # (equivalent to using joe:password... form above)br.add_proxy_password(joe, password) # Add HTTP Basic/Digest auth username and password for website access. br.add_password(http://example.com/protected/, joe, password) # Dont handle HTTP-EQUIV headers (HTTP headers embedded in HTML). br.set_handle_equiv(False) # Ignore robots.txt. Do not do this without thought and consideration. br.set_handle_robots(False) # Dont add Referer (sic) header br.set_handle_referer(False) # Dont handle Refresh redirections br.set_handle_refresh(False) # Dont handle cookies br.set_cookiejar() # Supply your own mechanize.CookieJar (NOTE: cookie handling is ON by # default: no need to do this unless you have some reason to use a # particular cookiejar) br.set_cookiejar(cj) # Log information about HTTP redirects and Refreshes. br.set_debug_redirects(True) # Log HTTP response bodies (ie. the HTML, most of the time). br.set_debug_responses(True) # Print HTTP headers. br.set_debug_http(True)# To make sure youre seeing all debug output: logger logging.getLogger(mechanize) logger.addHandler(logging.StreamHandler(sys.stdout)) logger.setLevel(logging.INFO)# Sometimes its useful to process bad headers or bad HTML: response br.response() # this is a copy of response headers response.info() # currently, this is a mimetools.Message headers[Content-type] text/html; charsetutf-8 response.set_data(response.get_data().replace(!---, !--)) br.set_response(response)另外还有一些类似于mechanize的网页交互模块 There are several wrappers around mechanize designed for functional testing of web applications: zope.testbrowser twill 归根到底都是对urllib2的封装因此选择一个比较好用的模块就好了 转载于:https://www.cnblogs.com/CBDoctor/p/3855738.html
http://www.pierceye.com/news/308312/

相关文章:

  • 网站布局手机百度网址大全
  • 企业网站做多大擦边球做网站挣钱
  • 网站怎么备份做网站建设要学多久
  • 怎样做买东西的网站外汇期货喊单网站怎么做的
  • 博客网站推荐郑州哪里做网站
  • 贵州建设职业技术学院网站网站开发 多语言
  • 网站后台管理系统怎么进重庆建设工程安全管理局网站
  • 移动网站开发的视频下载百度网盘下载官网
  • 在百度备案网站建设工程检测网
  • 广州企业网站营销电话公司网站怎么做啊
  • 如何利用视频网站做推广网站开发管理学什么
  • 福建漳发建设有限公司网站做网站申请什么商标
  • 专门做房产的网站上海网站开发毕业生
  • 网站域名已经解析但没有被百度等搜索引擎收录怎么办可以做投票功能的网站
  • 重庆网站设计总部什么是社交电商平台
  • 内容管理网站百度电商平台
  • 网站建设 万网网站统计插件
  • 怎么个人网站设计网站建设 不违背
  • 图片下载网站郑州联通网站备案
  • 名师工作室网站建设 意义o2o新零售系统
  • 域名查询权威网站网页设计基础填空题及答案
  • 网站建设策划方案如何写新开传奇新服网
  • dedecms网站上传服务器不是空间网站正则表达式怎么做
  • 青岛企业建设网站企业南宁网站开发建设
  • 网站备案是先做网站还是做完了备案效果好的手机网站建设
  • 做企业宣传网站沈阳妇科检查去哪个医院较好
  • 网站为什么维护wordpress 交易平台
  • 南京 电子商务网站5118数据分析平台官网
  • 试析企业网站建设模式建网站的网络公司
  • 内蒙古建设 招聘信息网站平台搭建