selenium+chromedriver刷点击量
#coding=utf-8 import re
import time
import json
import requests
from selenium import webdriver
from selenium.common.exceptions import TimeoutException
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC URL = u'www.baidu.com' def get_http_proxy_from_pool():
proxy = {}
try:
url = "xxxxxxxxxxxxxxxxxxxxxxxxxx"
response = requests.get(url)
jsonstr = response.text
result = json.loads(jsonstr)
if result.get("code") == 1:
proxy_list = result.get("data")
proxy_item = proxy_list[0]
proxy = {"http":"http://%s:%s"%(proxy_item.get("proxy_ip"),proxy_item.get("proxy_port"))}
else:
raise Exception("failed to get http proxy.")
except Exception as e:
print str(e)
finally:
return proxy def get_desired_capabilities():
proxy = get_http_proxy_from_pool().get(u"http")
print u"当前代理: %s" % proxy
options = webdriver.ChromeOptions()
desired_capabilities = options.to_capabilities()
desired_capabilities[u'proxy'] = {
u"httpProxy": proxy,
u"ftpProxy": proxy,
u"sslProxy": proxy,
u"noProxy": None,
u"proxyType": u"MANUAL",
u"class": u"org.openqa.selenium.Proxy",
u"autodetect": False}
return desired_capabilities def get_chrome_browser():
desired_capabilities = get_desired_capabilities()
browser = webdriver.Chrome(desired_capabilities = desired_capabilities)
return browser def get_headless_chrome_browser():
chrome_options = webdriver.ChromeOptions()
chrome_options.add_argument('headless')
desired_capabilities = get_desired_capabilities()
browser = webdriver.Chrome(desired_capabilities = desired_capabilities, chrome_options=chrome_options)
return browser def search_keyword(keyword):
browser = get_headless_chrome_browser()
#设置超时时间
wait = WebDriverWait(browser, 5)
try:
browser.get(URL)
#等待搜索框与搜索按钮加载完成
input = wait.until(EC.presence_of_element_located((By.ID, u'searchKey')))
input.send_keys(keyword)
button = wait.until(EC.element_to_be_clickable((By.ID, u'btn-search')))
button.click()
print u"%s搜索成功" % keyword
except Exception as e:
print(u'搜索过程出错')
finally:
browser.delete_all_cookies()
browser.close() def main():
results = get_company_from_mysql()
for result in results:
keyword = result[0] if result else ""
print keyword
search_keyword(keyword)
time.sleep(1) if __name__=='__main__':
main()
selenium+chromedriver刷点击量的更多相关文章
- Python一日一练05----怒刷点击量
功能 自己主动获取CSDN文章列表,并对每篇文章添加点击量. 源代码 import urllib.request import re import time import random from bs ...
- ASP.NET MVC WebApi 返回数据类型序列化控制(json,xml) 用javascript在客户端删除某一个cookie键值对 input点击链接另一个页面,各种操作。 C# 往线程里传参数的方法总结 TCP/IP 协议 用C#+Selenium+ChromeDriver 生成我的咕咚跑步路线地图 (转)值得学习百度开源70+项目
ASP.NET MVC WebApi 返回数据类型序列化控制(json,xml) 我们都知道在使用WebApi的时候Controller会自动将Action的返回值自动进行各种序列化处理(序列化为 ...
- python通过代理刷网页点击量
python通过代理刷网页点击量 更新异常处理情况 @time 2013-0803 更新循环里计数问题和随机等待时间问题 #!/usr/bin/python #-*- coding:utf-8 -*- ...
- 用C#+Selenium+ChromeDriver 生成我的咕咚跑步路线地图
先上结果: 之前 在公司业务中用过java+Selenium+ChromeDriver ,使用起来非常顺手,可以完美模拟真实的用户浏览行为.最近休息的时候想用C#也试一下,于是有了本文. 实现原理一样 ...
- selenium + ChromeDriver 实战系列之启信宝(一)
之前写了一篇selenium + ChromeDriver的一些入门的知识,这篇博客里面找了启信宝这个网站,简单的进行了一个实战练习.本篇博客的结构如下: 首先会给出一些使用seleniu ...
- phpcms文章点击量统计方法
phpcms用户广大,很好用,很傻瓜.设计思路也很好,对cms的常见功能都有设计,可以作为自己开发的参考. 最近看了下phpcms的源码关于文章点击量统计的这块,自己记录下. 默认文章点击量显示的位置 ...
- PHPCMS V9 栏目列表调用文章点击量及评论数量方法
很多朋友在用Phpcms做站时,具体需要在列表页.首页调用文章列表调用文章的点击量和评论排行,那么怎么才能做到在Phpcms v9首页.频道页.列表页.推荐位等页面获取文章浏览量和评论统计呢? 原因起 ...
- PHPCMS V9 点击量排行调用方法
首先调用的标签代码如下: {pc:content action=”sitehits” siteid=”4″ num=”10″ order=”views DESC” cache=”3600″} {loo ...
- .net 新闻点击量修改,避免恶意刷新
DataTable dt = bll.GetNewsByID(id);//根据ID获取的新闻详细内容 if (dt != null && dt.Rows.Count > 0) { ...
随机推荐
- Python标准库12 数学与随机数
想用高斯分布生成随机数,在网上看到很强大的总结,保留一下,以备后用 https://www.cnblogs.com/vamei/archive/2012/10/26/2741702.html
- python之面向对象高级
一.__slots__ 1.__slots__的概念:是一个变量,变量值可以是列表,元组,或者可迭代对象,也可以是一个字符串. 2.使用点来访问属性本质就是在访问类或者对象的__dict__属性字典( ...
- MySql 数据库安装、环境变量配置 以及 本地连接
一.准备 MySql 的安装包,这里我从网上下载的是 mysql-installer-community-5.6.21.1.msi,如下图: 二.,双击 mysql-installer-com ...
- Hibernate(7)关联关系_单向1对n
1.单向一对多(@OneToMany)关联是比较少用的(一般用双向一对多代替). 2.实体类: 1端:Publishers.java public class Publishers { private ...
- Aizu2170 Marked Ancestor(并查集)
https://vjudge.net/problem/Aizu-2170 并查集用于管理元素分组情况. 建树pre[]记录父节点,一开始只有结点1被标记了,所以find()最终得到的根都是1. 如果遇 ...
- ubuntu下使用crontab
创建crontab任务 参考:https://www.cnblogs.com/Icanflyssj/p/5138851.html 3. crontab常用的几个命令格式 crontab -l //显示 ...
- Java知识回顾 (9) 同步、异步IO
一.基本概念 同步和异步: 同步和异步是针对应用程序和内核的交互而言的. 同步指的是用户进程触发IO 操作并等待或者轮询的去查看IO 操作是否就绪: 而异步是指用户进程触发IO 操作以后便开始做自己的 ...
- java获得上下周及本周日期
public static SimpleDateFormat getFormat(String format) { return new SimpleDateFormat(format); } /** ...
- webview 向右滑动关闭时,怎么禁止此 webview 上下滚动?
webview 向右滑动关闭时,怎么禁止此 webview 上下滚动?
- Unity中调用DLL库
DLL -- Dynamic Link Library(动态链接库文件),这里以Window平台为例. Unity支持的两种语言生成的DLL库(C++.C#),这里以C#为例,C++网上可以搜索很详细 ...