selenium等待元素加载
bro.implicitly_wait(10)
selenium元素操作
click()
send_keys("内容")
clear()
执行js
-创建新的选项卡
-打印出一些变量(属于当前爬取的页面中的变量)
-获取当前登录的cookie
-滑动屏幕
import requests
import time
from selenium import webdriver
from selenium.webdriver.common.by import By
bro = webdriver.Chrome()
bro.get('https://www.pearvideo.com/category_1')
bro.implicitly_wait(10)
bro.maximize_window()
time.sleep(5)
bro.execute_script('open()')
bro.execute_script('alert(document.cookie)')
time.sleep(10)
bro.close()
切换选项卡
from selenium import webdriver
import time
bro = webdriver.Chrome()
bro.implicitly_wait(10)
bro.maximize_window()
bro.execute_script("open()")
time.sleep(1)
bro.switch_to.window(bro.window_handles[1])
bro.get('https://www.taobao.com')
time.sleep(2)
bro.switch_to.window(bro.window_handles[0])
bro.get('https://www.baidu.com')
time.sleep(2)
bro.execute_script('window.open()')
bro.execute_script('window.open()')
bro.close()
bro.quit()
登录cnblogs
import json
import time
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.options import Options
options = Options()
options.add_argument("--disable-blink-features=AutomationControlled")
bro = webdriver.Chrome(options=options)
bro.get("https://www.cnblogs.com/")
bro.maximize_window()
bro.implicitly_wait(10)
phone_input = bro.find_element(By.LINK_TEXT, '登录')
phone_input.click()
sms_login = bro.find_element(By.CSS_SELECTOR, "#mat-tab-label-0-1 > div")
sms_login.click()
username_input = bro.find_element(By.ID, "mat-input-3")
submit = bro.find_element(By.CSS_SELECTOR,
"#mat-tab-content-0-1 > div > div > app-verification-code-input > mat-form-field > div > "
"div.mat-form-field-flex.ng-tns-c47-8 > "
"div.mat-form-field-suffix.ng-tns-c47-8.ng-star-inserted > button")
code = bro.find_element(By.CSS_SELECTOR, "#mat-input-4")
username_input.send_keys("18436093205")
submit.click()
codes = bro.find_element(By.ID, "rectMask")
codes.click()
try:
code_sms = input("请输入验证码:")
code.send_keys(code_sms)
except Exception:
print("验证码错误")
login = bro.find_element(By.CSS_SELECTOR,
"body > app-root > app-sign-in-layout > div > div > app-sign-in > app-content-container > "
"div > div > div > form > div > button")
login.click()
time.sleep(10)
cookies = bro.get_cookies()
with open("cnblogs.json", "w", encoding="utf8") as f:
json.dump(cookies, f)
time.sleep(2)
bro.close()
抽屉半自动点赞
import json
import requests
from bs4 import BeautifulSoup
session = requests.Session()
cookie = {}
with open('chouti.json', 'r') as f:
cookie_list = json.load(f)
for item in cookie_list:
cookie[item['name']] = item['value']
header={'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36'}
res = session.get('https://dig.chouti.com/', cookies=cookie,headers=header)
soup = BeautifulSoup(res.text, 'html.parser')
print(res.text)
divs = soup.find_all(name='div', class_='link-item')
for div in divs:
article_id = div.attrs.get('data-id')
data = {
'linkId': article_id
}
res1 = session.post('https://dig.chouti.com/link/vote', data=data,headers=header)
print(res1.text)
xpath
-解析库自带的
-css选择器
-xpath--->通用的--->
即为XML路径语言(XML Path Language),它是一种用来确定XML文档中某部分位置的语言
nodename 选取此节点的所有子节点。
/ 从根节点选取。
// 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置。
. 选取当前节点。
.. 选取当前节点的父节点。
@ 选取属性。
doc = '''
<html>
<head>
<base href='http://example.com/' />
<title>Example website</title>
</head>
<body>
<div id='images'>
<a href='image1.html' id='lqz'>Name: My image 1 <br /><img src='image1_thumb.jpg' /></a>
<a href='image2.html'>Name: My image 2 <br /><img src='image2_thumb.jpg' /></a>
<a href='image3.html'>Name: My image 3 <br /><img src='image3_thumb.jpg' /></a>
<a href='image4.html'>Name: My image 4 <br /><img src='image4_thumb.jpg' /></a>
<a href='image5.html' class='li li-item' name='items'>Name: My image 5 <br /><img src='image5_thumb.jpg' /></a>
<a href='image6.html' name='items'><span><h5>test</h5></span>Name: My image 6 <br /><img src='image6_thumb.jpg' /></a>
</div>
</body>
</html>
'''
from lxml import etree
html = etree.HTML(doc)
'''
/
//
.
..
取文本 /text()
取属性 /@属性名
根据属性过滤 [@属性名=属性值]
class 特殊
[contains(@class,"li")]
'''
动作链
-形式一:
actions=ActionChains(bro)
actions.drag_and_drop(sourse,target)
actions.perform()
-方式二:
ActionChains(bro).click_and_hold(sourse).perform()
distance=target.location['x']-sourse.location['x']
track=0
while track < distance:
ActionChains(bro).move_by_offset(xoffset=2,yoffset=0).perform()
track+=2
from selenium import webdriver
from selenium.webdriver import ActionChains
from selenium.webdriver.support.wait import WebDriverWait
import time
from selenium.webdriver.common.by import By
driver = webdriver.Chrome()
driver.get('http://www.runoob.com/try/try.php?filename=jqueryui-api-droppable')
driver.implicitly_wait(3)
driver.maximize_window()
try:
driver.switch_to.frame('iframeResult')
sourse = driver.find_element(By.ID, 'draggable')
target = driver.find_element(By.ID, 'droppable')
ActionChains(driver).click_and_hold(sourse).perform()
distance=target.location['x']-sourse.location['x']
track = 0
while track < distance:
ActionChains(driver).move_by_offset(xoffset=2, yoffset=0).perform()
track += 2
ActionChains(driver).release().perform()
time.sleep(10)
finally:
driver.close()
自动登录12306
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~