前两天总结了一下python爬虫 使用真实浏览器打开网页的两种方法总结
但那仅仅是总结一下而已,今天本文来实战演练一下
依然使用的是 webbrowser 这个模块 来调用浏览器
关于的三种打开方式在上一篇文章中已经说过了,这里不再赘述
如果没有特意注册,那么将会是使用默认的浏览器来打开网页,如下:
#默认浏览器 #coding:utf-8 import webbrowser as web #对导入的库进行重命名 def run_to_use_default_browser_open_url(url): web.open_new_tab(url) print 'run_to_use_default_browser_open_url open url ending ....'
真正的注册一个非默认浏览器:
这里先用的firfox浏览器
#firefox浏览器
def use_firefox_open_url(url):
browser_path=r'C:\Program Files (x86)\Mozilla Firefox\firefox.exe'
#这里的‘firefox'只是一个浏览器的代号,可以命名为自己认识的名字,只要浏览器路径正确
web.register('firefox', web.Mozilla('mozilla'), web.BackgroundBrowser(browser_path))
#web.get('firefox').open(url,new=1,autoraise=True)
web.get('firefox').open_new_tab(url)
print 'use_firefox_open_url open url ending ....'
解释一下这个注册函数当前的用法
web.register() 它的三个参数
第一个为 自己给浏览器重新命的名字, 主要目的是为了在之后的调用中,使用者能够找到它
第二个参数, 可以按照这样上面的例子这样写,因为python本身将一些浏览器实例化了, 但是还是推荐 将其赋值为 None ,因为这个参数没有更好,毕竟有些浏览器python本身并没有实例化,而这个参数也不影响它的使用
第三个参数,目前所知是浏览器的路径, 不知道有没有别的写法
当然,这里只是在这里的用法, 函数本身的意思可以去源文件中查看
下面给我一些测试的实例:
#coding:utf-8
import webbrowser as web #对导入的库进行重命名
import os
import time
#默认浏览器
def run_to_use_default_browser_open_url(url):
web.open_new_tab(url)
print 'run_to_use_default_browser_open_url open url ending ....'
#firefox浏览器
def use_firefox_open_url(url):
browser_path=r'C:\Program Files (x86)\Mozilla Firefox\firefox.exe'
#这里的‘firefox'只是一个浏览器的代号,可以命名为自己认识的名字,只要浏览器路径正确
web.register('firefox', web.Mozilla('mozilla'), web.BackgroundBrowser(browser_path))
#web.get('firefox').open(url,new=1,autoraise=True)
web.get('firefox').open_new_tab(url)
print 'use_firefox_open_url open url ending ....'
#谷歌浏览器
def use_chrome_open_url(url):
browser_path=r'C:\Program Files (x86)\Google\Chrome\Application\chrome.exe'
web.register('chrome', None,web.BackgroundBrowser(browser_path))
web.get('chrome').open_new_tab(url)
print 'use_chrome_open_url open url ending ....'
#Opera浏览器
def use_opera_open_url(url):
browser_path=r'C:\Program Files (x86)\Opera\launcher.exe'
web.register('opera', None,web.BackgroundBrowser(browser_path))
web.get('chrome').open_new_tab(url)
print 'use_opera_open_url open url ending ....'
#千影浏览器
def use_qianying_open_url(url):
browser_path=r'C:\Users\Administrator\AppData\Roaming\qianying\qianying.exe'
web.register('qianying', None,web.BackgroundBrowser(browser_path))
web.get('qianying').open_new_tab(url)
print 'use_qianying_open_url open url ending ....'
#115浏览器
def use_115_open_url(url):
browser_path=r'C:\Users\Administrator\AppData\Local\115Chrome\Application\115chrome.exe'
web.register('115', None,web.BackgroundBrowser(browser_path))
web.get('115').open_new_tab(url)
print 'use_115_open_url open url ending ....'
#IE浏览器
def use_IE_open_url(url):
browser_path=r'C:\Program Files (x86)\Internet Explorer\iexplore.exe'
web.register('IE', None,web.BackgroundBrowser(browser_path))
web.get('IE').open_new_tab(url)
print 'use_IE_open_url open url ending ....'
#搜狗浏览器
def use_sougou_open_url(url):
browser_path=r'D:\Program Files(x86)\SouExplorer\SogouExplorer\SogouExplorer.exe'
web.register('sougou', None,web.BackgroundBrowser(browser_path))
web.get('sougou').open_new_tab(url)
print 'use_sougou_open_url open url ending ....'
#浏览器关闭任务
def close_broswer():
os.system('taskkill /f /IM SogouExplorer.exe')
print 'kill SogouExplorer.exe'
os.system('taskkill /f /IM firefox.exe')
print 'kill firefox.exe'
os.system('taskkill /f /IM Chrome.exe')
print 'kill Chrome.exe'
os.system('taskkill /f /IM launcher.exe')
print 'kill launcher.exe'
os.system('taskkill /f /IM qianying.exe')
print 'kill qianying.exe'
os.system('taskkill /f /IM 115chrome.exe')
print 'kill 115chrome.exe'
os.system('taskkill /f /IM iexplore.exe')
print 'kill iexplore.exe'
#测试运行主程序
def broswer_test():
url='https://www.baidu.com'
run_to_use_default_browser_open_url(url)
use_firefox_open_url(url)
#use_chrome_open_url(url)
use_qianying_open_url(url)
use_115_open_url(url)
use_IE_open_url(url)
use_sougou_open_url(url)
time.sleep(20)#给浏览器打开网页一些反应时间
close_broswer()
if __name__ == '__main__':
print '''''
*****************************************
** Welcome to python of browser **
** Created on 2017-05-07 **
** @author: Jimy _Fengqi **
*****************************************
'''
broswer_test()
好了,上面的程序是测试实例, 下面对这些内容做一个整合,简化一下代码,来实现本文的根本目的
#coding:utf-8
import time
import webbrowser as web
import os
import random
#随机选择一个浏览器打开网页
def open_url_use_random_browser():
#定义要访问的地址
url='https://www.baidu.com'
#定义浏览器路径
browser_paths=[r'C:\Program Files (x86)\Mozilla Firefox\firefox.exe',
r'C:\Program Files (x86)\Google\Chrome\Application\chrome.exe',
r'C:\Program Files (x86)\Opera\launcher.exe',
r'C:\Users\Administrator\AppData\Roaming\qianying\qianying.exe',
r'C:\Users\Administrator\AppData\Local\115Chrome\Application\115chrome.exe',
r'C:\Program Files (x86)\Internet Explorer\iexplore.exe',
r'D:\Program Files(x86)\SouExplorer\SogouExplorer\SogouExplorer.exe'
]
#选择一个浏览器
def chose_a_browser_open_url(browser_path,url):
#如果传入的浏览器位置不存在,使用默认的浏览器打开
if not browser_path:
print 'using default browser to open url'
web.open_new_tab(url)#使用默认浏览器,就不再结束进程
else:
#判断浏览器路径是否存在
if not os.path.exists(browser_path):
print 'current browser path not exists,using default browser'
#浏览器位置不存在就使用默认的浏览器打开
browser_path=''
chose_a_browser_open_url(chose_a_browser_open_url,url)
else:
browser_task_name=browser_path.split('\\')[-1]#结束任务的名字
browser_name=browser_task_name.split('.')[0]#自定义的浏览器代号
print browser_name
web.register(browser_name, None,web.BackgroundBrowser(browser_path))
web.get(browser_name).open_new_tab(url)#使用新注册的浏览器打开网页
print 'using %s browser open url successful' % browser_name
time.sleep(5)#等待打开浏览器
kill_cmd='taskkill /f /IM '+browser_task_name#拼接结束浏览器进程的命令
os.system(kill_cmd) #终结浏览器
browser_path=random.choice(browser_paths)#随机从浏览器中选择一个路径
chose_a_browser_open_url(browser_path,url)
if __name__ == '__main__':
print '''''
*****************************************
** Welcome to python of browser **
** Created on 2017-05-07 **
** @author: Jimy _Fengqi **
*****************************************
'''
open_url_use_random_browser()
PS:本程序在windows上面运行,python版本是2.7
以上这篇python实现随机调用一个浏览器打开网页就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
调用浏览器打开网页
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。